create TABLE:
1:mysql> CREATE TABLE test
-> (a int not null auto_increment,primary key (a), key(b))
-> SELECT b,c from test2;
这将创建一个有3个列(a,b,c)的表,其中b,c列的数据来自表test2。注意如果在拷贝数据进表时发生任何错误,表将自动被删
除。
2、可以通过选择一个表的全部内容(无 WHERE 子句)来拷贝一个表,或利用一个总是失败的 WHERE 子句来创建一个空表,
如:
mysql> CREATE TABLE test SELECT * from test2;
mysql> CREATE TABLE test SELECT * from test2 where 0;
如果希望利用 LOAD DATA 将一个数据文件装入原来的文件中,而不敢肯定是否具有指定的正确数据格式时,创建空拷贝很
有用。您并不希望在第一次未得到正确的选项时以原来表中畸形的记录而告终。利用原表的空拷贝允许对特定的列和行分隔符用
LOAD DATA 的选项进行试验,直到对输入数据的解释满意时为止。在满意之后,就可以将数据装入原表了。
3、create table payment_myisam like payment;
insert into:
1:
- 如果两表字段相同,则可以直接这样用。
insert into table_a select * from table_b
- 如果两表字段不同,a表需要b中的某几个字段即可,则可以如下使用:
insert into table_a(field_a1,field_a2,field_a3) select (field_b1,field_b2,field_b3) from table_b //即是上一个语法的扩展
例:insert into a select * from b; //向存在表中插入数据,如果不存在表a报错
注:要求目标表table_a必须存在,由于目标表table_a已经存在,所以我们除了插入源表table_b的字段外,还可以插入常量。
(注:以上语句前提条件是每个字段对应的字段类型相同或可以自动转换。)
- Select value1, ... into Table2 from Table1; --不仅能对表操作,还能用该句型为变量table2赋值
例:select * into a from b; --创建新表的同时插入数据,如果表a存在,报错。
group by:
group by语法可以根据给定数据列的每个成员(即group by后面的成员)对查询结果进行分组统计(统计时一般需要使用聚合函数),最终得到一个分组汇总表。
Select子句中的列名一般都包含列函数(因为使用group by的目的即是对每个分组进行统计,统计需要使用列函数),同时也包含了方便查看统计结果的某些字段(某些字段一般都会有group by后面的字段)。其中,列函数对于group by子句定义的每个组各返回一个结果。
原数据表STAFF:
id name dept salary edlevel hiredate
1 张三 开发部 2000 3 2009-10-11
2 李四 开发部 2500 3 2009-10-01
3 王五 设计部 2600 5 2010-10-02
4 王六 设计部 2300 4 2010-10-03
5 马七 设计部 2100 4 2010-10-06
6 赵八 销售部 3000 5 2010-10-05
7 钱九 销售部 3100 7 2010-10-07
8 孙十 销售部 3500 7 2010-10-06
例1:列出每个部门最高薪水的结果,sql语句如下:
SELECT DEPT, MAX(SALARY) AS MAXIMUM
FROM STAFF
GROUP BY DEPT
查询结果如下:
DEPT MAXIMUM
开发部 2500
设计部 2600
销售部 3500
解释一下结果:
1、语句SELECT子句中的列名包含了列函数,即MAX(SALARY);同时也包含了方便查看统计结果的某些字段,即DEPT(其
为group by后面的字段)。
2、“列函数对于GROUP BY子句定义的每个组各返回一个结果”,根据部门分组,对每个部门返回一个结果,就是每个部门的最
高薪水。
注意:计算的是每个部门(由 GROUP BY 子句定义的组)而不是整个公司的 MAX(SALARY)。
例2:将 WHERE 子句与 GROUP BY 子句一起使用
分组查询可以在形成组和计算列函数之前具有消除非限定行的标准 WHERE 子句。必须在GROUP BY 子句之前指定
WHERE 子句。
如,查询公司2010年入职的各个部门每个级别里的最高薪水:
SELECT DEPT, EDLEVEL, MAX( SALARY ) AS MAXIMUM
FROM staff
WHERE HIREDATE > '2010-01-01'
GROUP BY DEPT,EDLEVEL
ORDER BY DEPT, EDLEVEL
查询结果如下:
DEPT EDLEVEL MAXIMUM
设计部 4 2300
设计部 5 2600
销售部 5 3000
销售部 7 3500
注意:在SELECT语句中指定的每个列名也在GROUP BY子句中提到,故语句正确。
GROUP BY子句对DEPT和EDLEVEL的每个唯一组合各返回一行。
例3:GROUP BY子句之后使用HAVING子句
HAVING表示对分类后的结果再进行条件的过滤。HAVING子句可包含一个或多个用AND和OR连接的谓词。
如:寻找雇员数超过2个的部门的最高和最低薪水:
SELECT DEPT, MAX( SALARY ) AS MAXIMUM, MIN( SALARY ) AS MINIMUM
FROM staff
GROUP BY DEPT
HAVING COUNT( * ) >2
ORDER BY DEPT //注:order by始终放在语句最后
查询结果如下:
DEPT MAXIMUM MINIMUM
设计部 2600 2100
销售部 3500 3000
如:寻找雇员平均工资大于3000的部门的最高和最低薪水:
SELECT DEPT, MAX( SALARY ) AS MAXIMUM, MIN( SALARY ) AS MINIMUM
FROM staff
GROUP BY DEPT
HAVING AVG( SALARY ) >3000
ORDER BY DEPT
查询结果如下:
DEPT MAXIMUM MINIMUM
销售部 3500 3000
select:
- 查看MYSQL数据库中所有用户:SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user; (两个单引号表示字符串中的单引号)
显示:
+---------------------------------+
| query |
+---------------------------------+
| user:'root'@'127.0.0.1'; |
| user:'root'@'::1'; |
| user:'lisa'@'localhost'; |
| user:'root'@'localhost'; |
| user:'z1'@'localhost'; |
+---------------------------------+
- 查看默认SQL Mode: select @@sql_mode;
- 查看当前MySQL是否支持profile: select @@have_profiling;
查看profiling是否是关闭的(默认是关闭的,即值为0):select @@profiling;
通过set语句在Session级别开启profiling: set profiling=1;
explain:
explain显示了mysql如何使用索引来处理select语句以及连接表。可以帮助选择更好的索引和写出更优化的查询语句。使用方法,在select语句前加上explain就可以了。
- explain select surname,first_name form a,b where a.id=b.id ;
- explain partitions select count(1) from emp where store_id >= 25 \G; //分区扫描,统计商店ID大于25的记录数