sql查询语句的格式,都是通用的,比如mysql和oracle,都是类似,例子如下:
SQL是3个表的查询,会给出表以及3个表之间的约束关系
Student 表
No编号
Name 姓名
Birthday 生日
bj 班级
jg 籍贯
adds地址
number电话
Course 表
Kcbh课程编号
kcmc课程名称
Source 表
Cjguid (主键)
No 编号
kcbh 课程编号
cj成绩
/
-- (1)查询学生籍贯为‘湖北’生日为1995-10-3的所有信息
select
from Student
where 1=1
and jg = '湖北' -- 籍贯为‘湖北’
and Birthday = '1995-10-3' -- 生日为1995-10-3
-- (2)查询学生姓名为‘王华’的各课程的平均分,最高分,最低分,总分。
select
avg(kcbh) as 平均分,
max(kcbh) as 最高分,
min(kcbh) as 最低分,
sum(kcbh) as 总分
from Source
where 1=1
and exists (select 1
from Student
where 1=1
and StudentNo = SourceNo
Name = '王华' -- 姓名为‘王华’
)
-- (3)没有太看题,大致是要求查询4,5列以上的信息,其中3个表各包含一些信息
select
StudentName as 学生,
Coursekcmc as 课程,
Sourcecj as 成绩
from Student,
Course,
Source,
where 1=1
and StudentNo = SourceNo
and CourseKcbh = Sourcekcbh
mysqldump备份还原和mysqldump导入导出语句大全详解
mysqldump备份:
mysqldump -u用户名 -p密码 -h主机数据库 a -w "sql条件" --lock-all-tables >路径
案例:
mysqldump -uroot -p1234 -hlocalhost db1 a -w "id in (select id from b)" --lock-all-tables > c:\aatxt
mysqldump还原:
mysqldump -u用户名 -p密码 -h主机数据库<路径
案例:
mysql -uroot -p1234 db1 < c:\aatxt
mysqldump按条件导出:
mysqldump -u用户名 -p密码 -h主机数据库 a --where "条件语句" --no-建表>路径
mysqldump -uroot -p1234 dbname a --where "tag='88'" --no-create-info> c:\asql
mysqldump按导入:
mysqldump -u用户名 -p密码 -h主机数据库<路径
案例:
mysql -uroot -p1234 db1 < c:\atxt
mysqldump导出表:
mysqldump -u用户名 -p密码 -h主机数据库表
案例:
mysqldump -uroot -p sqlhk9 a --no-data
讲一下 mysqldump 的一些主要参数
--compatible=name
它告诉 mysqldump,导出的数据将和哪种数据库或哪个旧版本的 MySQL 服务器相兼容。值可以为 ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options 等,要使用几个值,用逗号将它们隔开。当然了,它并不保证能完全兼容,而是尽量兼容。
--complete-insert,-c
导出的数据采用包含字段名的完整 INSERT 方式,也就是把所有的值都写在一行。这么做能提高插入效率,但是可能会受到 max_allowed_packet 参数的影响而导致插入失败。因此,需要谨慎使用该参数,至少我不推荐。
--default-character-set=charset
指定导出数据时采用何种字符集,如果数据表不是采用默认的 latin1 字符集的话,那么导出时必须指定该选项,否则再次导入数据后将产生乱码问题。
--disable-keys
告诉 mysqldump 在 INSERT 语句的开头和结尾增加 /!40000 ALTER TABLE table DISABLE KEYS /; 和 /!40000 ALTER TABLE table ENABLE KEYS /; 语句,这能大大提高插入语句的速度,因为它是在插入完所有数据后才重建索引的。该选项只适合 MyISAM 表。
--extended-insert = true|false
默认情况下,mysqldump 开启 --complete-insert 模式,因此不想用它的的话,就使用本选项,设定它的值为 false 即可。
--hex-blob
使用十六进制格式导出二进制字符串字段。如果有二进制数据就必须使用本选项。影响到的字段类型有 BINARY、VARBINARY、BLOB。
--lock-all-tables,-x
在开始导出之前,提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭 --single-transaction 和 --lock-tables 选项。
--lock-tables
它和 --lock-all-tables 类似,不过是锁定当前导出的数据表,而不是一下子锁定全部库下的表。本选项只适用于 MyISAM 表,如果是 Innodb 表可以用 --single-transaction 选项。
--no-create-info,-t
只导出数据,而不添加 CREATE TABLE 语句。
--no-data,-d
不导出任何数据,只导出数据库表结构。
--opt
这只是一个快捷选项,等同于同时添加 --add-drop-tables --add-locking --create-option --disable-keys --extended-insert --lock-tables --quick --set-charset 选项。本选项能让 mysqldump 很快的导出数据,并且导出的数据能很快导回。该选项默认开启,但可以用 --skip-opt 禁用。注意,如果运行 mysqldump 没有指定 --quick 或 --opt 选项,则会将整个结果集放在内存中。如果导出大数据库的话可能会出现问题。
--quick,-q
该选项在导出大表时很有用,它强制 mysqldump 从服务器查询取得记录直接输出而不是取得所有记录后将它们缓存到内存中。
--routines,-R
导出存储过程以及自定义函数。
--single-transaction
该选项在导出数据之前提交一个 BEGIN SQL语句,BEGIN 不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于事务表,例如 InnoDB 和 BDB。
本选项和 --lock-tables 选项是互斥的,因为 LOCK TABLES 会使任何挂起的事务隐含提交。
要想导出大表的话,应结合使用 --quick 选项。
--triggers
同时导出触发器。该选项默认启用,用 --skip-triggers 禁用它。
其他参数详情请参考手册,我通常使用以下 SQL 来备份 MyISAM 表:
/usr/local/mysql/bin/mysqldump -uyejr -pyejr "
--default-character-set=utf8 --opt --extended-insert=false "
--triggers -R --hex-blob -x db_name > db_namesql
使用以下 SQL 来备份 Innodb 表:
/usr/local/mysql/bin/mysqldump -uyejr -pyejr "
--default-character-set=utf8 --opt --extended-insert=false "
--triggers -R --hex-blob --single-transaction db_name > db_namesql
另外,如果想要实现在线备份,还可以使用 --master-data 参数来实现,如下:
/usr/local/mysql/bin/mysqldump -uyejr -pyejr "
--default-character-set=utf8 --opt --master-data=1 "
--single-transaction --flush-logs db_name > db_namesql
它只是在一开始的瞬间请求锁表,然后就刷新binlog了,而后在导出的文件中加入CHANGE MASTER 语句来指定当前备份的binlog位置,如果要把这个文件恢复到slave里去,就可以采用这种方法来做。
12 还原
用 mysqldump 备份出来的文件是一个可以直接倒入的 SQL 脚本,有两种方法可以将数据导入。
直接用 mysql 客户端
例如:
/usr/local/mysql/bin/mysql -uyejr -pyejr db_name < db_namesql
用 SOURCE 语法(实验不成功!!!)
其实这不是标准的 SQL 语法,而是 mysql 客户端提供的功能,例如:
SOURCE /tmp/db_namesql;
这里需要指定文件的绝对路径,并且必须是 mysqld 运行用户(例如 nobody)有权限读取的文件。
更新前几个字符用substr函数。
如test表中有如下数据:
现要将“财务”二字改成“财务”,可用如下语句:
update test set dept='财务'||substr(dept,-1) where dept='财务部';commit;
更新后结果:
2016软件测试final免费下载
rtpi
软件测试(英语:Software Testing),描述一种用来促进鉴定软件的正确性、完整性、安全性和质量的过程。换句话说,软件测试是一种实际输出与预期输出之间的审核或者比较过程。软件测试的经典定义是:在规定的条件下对程序进行 *** 作,以发现程序错误,衡量软件质量,并对其是否能满足设计要求进行评估的过程。
11 运行SQL程序
12 Microsoft Access
13 Microsoft SQL Server
131 SQL Server 2000
132 SQL Server 2005/2008
14 Oracle
15 IBM DB2
16 MySQL
17 PostgreSQL 21 表、列和行
211 表
212 列
213 行
22 主键
23 外键
24 联系
241 一对一
242 一对多
243 多对多
25 规范化
251 第一范式
252 第二范式
253 第三范式
254 其他范式
26 示例数据库
261 表authors
262 表publishers
263 表titles
264 表titles_authors
265 表royalties
27 创建示例数据库 31 SQL语法
32 SQL标准和一致性
33 标识符
34 数据类型
35 字符串类型
36 二进制大型对象类型
37 精确数字类型
38 近似数字类型
39 布尔类型
310 日期和时间类型
311 时间间隔类型
312 唯一标识符
313 其他数据类型
314 空值 41 使用SELECT和FROM检索列
42 使用AS创建列的别名
43 使用DISTINCT消除重复的行
44 使用ORDER BY排序行
45 使用WHERE筛选行
46 使用AND、OR和NOT组合及求反条件
461 AND *** 作符
462 OR *** 作符
463 NOT *** 作符
464 AND、OR和NOT一起使用
47 使用LIKE匹配模式
48 使用BETWEEN进行范围筛选
49 使用IN进行列表筛选
410 使用IS NULL测试空值 51 创建派生列
52 执行算术运算
53 确定计算的顺序
54 使用||连接串
55 使用SUBSTRING()提取子串
56 使用UPPER()和LOWER()更改串的大小写
57 使用TRIM()修整字符
58 使用CHARACTER_LENGTH()得到串长度
59 使用POSITION()查找子串
510 执行日期及时间间隔运算
511 获得当前日期和时间
512 获得用户信息
513 使用CAST()转换数据类型
514 使用CASE计算条件值
515 使用COALESCE()检查空值
516 使用NULLIF()比较表达式 61 使用聚合函数
62 创建聚合表达式
63 使用MIN()查找最小值
64 使用MAX()查找最大值
65 使用SUM()计算总和
66 使用AVG()计算平均值
67 使用COUNT()统计行数
68 使用DISTINCT聚合不重复的值
69 使用GROUP BY分组行
610 使用HAVING筛选分组 71 限定列名
72 使用AS创建表的别名
73 使用联结
74 使用JOIN或WHERE创建联结
75 使用CROSS JOIN创建交叉联结
76 使用NATURAL JOIN创建自然联结
77 使用INNER JOIN创建内联结
78 使用OUTER JOIN创建外联结
79 创建自联结 81 理解子查询
82 子查询语法
83 子查询和联结
84 简单子查询和相关子查询
841 简单子查询
842 相关子查询
85 在子查询中限定列名
86 子查询中的空值
87 使用子查询作为列表达式
88 使用比较 *** 作符比较子查询的值
89 使用IN测试集合成员资格
810 使用ALL比较所有子查询的值
811 使用ANY比较某些子查询的值
812 使用EXISTS检测存在性
813 比较等价查询 91 使用UNION合并行
92 使用INTERSECT查找相同行
93 使用EXCEPT查找不同行 101 显示表结构
102 使用INSERT插入行
103 使用UPDATE更新行
104 使用DELETE删除行 111 创建表
112 理解约束
113 使用CREATE TABLE创建新表
114 使用NOT NULL禁止空值
115 使用DEFAULT确定默认值
116 使用PRIMARY KEY指定主键
117 使用FOREIGN KEY指定外键
118 使用UNIQUE确保值唯一
119 使用CHECK创建检查约束
1110 使用CREATE TEMPORARY TABLE创建临时表
1111 使用CREATE TABLE AS利用已存在表创建新表
1112 使用ALTER TABLE修改表
1113 使用DROP TABLE删除表 121 使用CREATE INDEX创建索引
122 使用DROP INDEX删除索引 131 使用CREATE VIEW创建视图
132 通过视图检索数据
133 通过视图修改数据
1331 通过视图插入行
1332 通过视图更新行
1333 通过视图删除行
134 使用DROP VIEW删除视图 151 动态统计
152 产生序列
153 发现等差数列、递增数列和等值数列
154 限定返回行的数量
1541 Microsoft Access
1542 Microsoft SQL Server
1543 Oracle
1544 IBM DB2
1545 MySQL
1546 PostgreSQL
155 分配排名
156 计算修整均值
157 随机选取行
158 处理重复值
159 创建电话列表
1510 检索元数据
15101 Microsoft Access
15102 Microsoft SQL Server
15103 Oracle
15104 IBM DB2
15105 MySQL
15106 PostgreSQL
1511 处理日期
15111 Microsoft Access
15112 Microsoft SQL Server
15113 Oracle
15114 IBM DB2
15115 MySQL
15116 PostgreSQL
1512 计算中值
1513 查询极值
1514 改变动态统计的中流
1515 旋转结果
1516 处理层次结构
索引
对于 Oracle 数据库,要查询全部表的话,需要这么写
GRANT SELECT ANY TABLE TO 数据库用户;
对于 SQL Server 数据库,要查询 某个数据库的全部表的话,需要这么写
先
USE 指定的数据库
GO
然后
GRANT SELECT TO 数据库用户
GO
这样, 这个数据库用户 就可以 SELECT 指定的数据库下的所有的表
以上就是关于sql如何查询语句的格式怎么写全部的内容,包括:sql如何查询语句的格式怎么写、mysql中备份和还原数据库的语句什么啊、oracle如何更新某列数据的前几个字符等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)