标签:column 技术 base select 连接字符串 第一个 薪资 无法 直接
一、单表查询的语法
select 字段1,字段2,字段3.。。from 表名
where 条件
group by field 分领域(组)查询
having 筛选
distinct 避免重复
order by field 排序查询
limit 限制条件查询
二、关键字的执行优先级(重点)
重点中的重点:
1、where
2、group by
3、having
4、select
5、distinct
6、order by
7、limit
a、找到表:from
b、拿着where指定的约束条件,去文件/表中取一条条记录
c、将取出的一条条记录进行分组group by,如果没有group by,则整体作为一组
d、将分组的结果进行having过滤
e、执行select
f、distinct去重
g、将结果按条件进行:order by
h、限制结果的显示条数
三、简单查询
1 company.employee 2 员工id id int 3 姓名 emp_name varchar 4 性别 sex enum 5 年龄 age int 6 入职日期 hire_date date 7 岗位 post varchar 8 职位描述 post_comment varchar 9 薪水 salary double 10 办公室 office int 11 部门编号 depart_id int 12 13 14 15 #创建表 16 create table employee( 17 id int not null unique auto_increment, 18 name varchar(20) not null, 19 sex enum(‘male‘,‘female‘) not null default ‘male‘, #大部分是男的 20 age int(3) unsigned not null default 28, 21 hire_date date not null, 22 post varchar(50), 23 post_comment varchar(100), 24 salary double(15,2), 25 office int, #一个部门一个屋子 26 depart_id int 27 ); 28 29 30 #查看表结构 31 mysql> desc employee; 32 +--------------+-----------------------+------+-----+---------+----------------+ 33 | Field | Type | Null | Key | Default | Extra | 34 +--------------+-----------------------+------+-----+---------+----------------+ 35 | id | int(11) | NO | PRI | NULL | auto_increment | 36 | name | varchar(20) | NO | | NULL | | 37 | sex | enum(‘male‘,‘female‘) | NO | | male | | 38 | age | int(3) unsigned | NO | | 28 | | 39 | hire_date | date | NO | | NULL | | 40 | post | varchar(50) | YES | | NULL | | 41 | post_comment | varchar(100) | YES | | NULL | | 42 | salary | double(15,2) | YES | | NULL | | 43 | office | int(11) | YES | | NULL | | 44 | depart_id | int(11) | YES | | NULL | | 45 +--------------+-----------------------+------+-----+---------+----------------+ 46 47 #插入记录 48 #三个部门:教学,销售,运营 49 insert into employee(name,sex,age,hire_date,post,salary,office,depart_id) values 50 (‘egon‘,‘male‘,18,‘20170301‘,‘老男孩驻沙河办事处外交大使‘,7300.33,401,1), #以下是教学部 51 (‘alex‘,‘male‘,78,‘20150302‘,‘teacher‘,1000000.31,401,1), 52 (‘wupeiqi‘,‘male‘,81,‘20130305‘,‘teacher‘,8300,401,1), 53 (‘yuanhao‘,‘male‘,73,‘20140701‘,‘teacher‘,3500,401,1), 54 (‘liwenzhou‘,‘male‘,28,‘20121101‘,‘teacher‘,2100,401,1), 55 (‘jingliyang‘,‘female‘,18,‘20110211‘,‘teacher‘,9000,401,1), 56 (‘jinxin‘,‘male‘,18,‘19000301‘,‘teacher‘,30000,401,1), 57 (‘成龙‘,‘male‘,48,‘20101111‘,‘teacher‘,10000,401,1), 58 59 (‘歪歪‘,‘female‘,48,‘20150311‘,‘sale‘,3000.13,402,2),#以下是销售部门 60 (‘丫丫‘,‘female‘,38,‘20101101‘,‘sale‘,2000.35,402,2), 61 (‘丁丁‘,‘female‘,18,‘20110312‘,‘sale‘,1000.37,402,2), 62 (‘星星‘,‘female‘,18,‘20160513‘,‘sale‘,3000.29,402,2), 63 (‘格格‘,‘female‘,28,‘20170127‘,‘sale‘,4000.33,402,2), 64 65 (‘张野‘,‘male‘,28,‘20160311‘,‘operation‘,10000.13,403,3), #以下是运营部门 66 (‘程咬金‘,‘male‘,18,‘19970312‘,‘operation‘,20000,403,3), 67 (‘程咬银‘,‘female‘,18,‘20130311‘,‘operation‘,19000,403,3), 68 (‘程咬铜‘,‘male‘,18,‘20150411‘,‘operation‘,18000,403,3), 69 (‘程咬铁‘,‘female‘,18,‘20140512‘,‘operation‘,17000,403,3) 70 ; 71 72 #ps:如果在windows系统中,插入中文字符,select的结果为空白,可以将所有字符编码统一设置成gbk
#简单查询 select id,name,sex...from employee; select * from employee; select name,age from employee; #避免重复 distinct select distinct post from employee; #通过四则运算查询 select name,salary*12 from employee; select name,salary*12 as annual_salary from employee; select name,salary*12 annual_salary from employee; #定义显示格式 concat()函数用于连接字符串 select concat(‘姓名:‘,name,‘年薪:‘,salary*12) as annual_salary from employee; concat_ws() 第一个参数为分隔符 select concat_ws(‘:‘,name,salary*12) as annual_salary from employee; #查出所有员工的名字,薪资,格式为<名字:egon> <薪资:3000> select concat(‘<名字:‘,name,‘> ‘,‘<薪资:‘,salary,‘>‘) from employee; #查出所有的岗位(去掉重复) select distinct depart_id from employee; #查出所有员工名字,以及他们的年薪,年薪的字段名为annual_salary
四、where 约束
where自居中可以使用:
1、比较运算符:> < >= <= !=
2、between 80 and 100值在80到100之间
3、in(80,90,100)值是80,90或100
4、like ‘egon%’
pattern 可以是% 或_,
%表示任意多字符,_表示一个字符,其中_最多为3个。
5、逻辑运算符:在多个条件直接可以使用逻辑运算符 and or not
#1、单条件查询 select name from employee where post=‘sale‘; #2、多条件查询 select name,salary from employee where post=‘teacher‘ and salary>10000; #3、关键字between and select name,salary from employee where salary between 5000 and 20000; select name,salary from employee where salary not between 5000 and 20000; #4、关键字is null(判断某个字段是否为null不能用等号,需要用is) select name,post_comment from employee where post_comment is null; select name,post_comment from employee where post_comment is not null; select name,post_comment from employee where post_comment=‘‘;注意‘‘是空字符串,不是null ps: 执行 update employee set post_comment=‘‘ where id=2; 再用上条查看就有结果了。
#5、关键字in集合查询 select name,salary from employee where salary=3000 or salary=3500 or salary=4000 or salary=9000; select name,salary from employee where salary in(300,3500,4000,9000); select name,salary from employee where salary not in(300,3500,4000,9000); #6、关键字like模糊查询 通配符‘%’ select * from employee where name like ‘eg%‘; select * from employee where post like ‘tea%‘; 通配符‘_‘ select * from employee where name like ‘a___‘; select * from employee where name like ‘wu_____‘; select * from employee where name like ‘______‘;
1. 查看岗位是teacher的员工姓名、年龄 2. 查看岗位是teacher且年龄大于30岁的员工姓名、年龄 3. 查看岗位是teacher且薪资在9000-1000范围内的员工姓名、年龄、薪资 4. 查看岗位描述不为NULL的员工信息 5. 查看岗位是teacher且薪资是10000或9000或30000的员工姓名、年龄、薪资 6. 查看岗位是teacher且薪资不是10000或9000或30000的员工姓名、年龄、薪资 7. 查看岗位是teacher且名字是jin开头的员工姓名、年薪
1、select name,age from employee where post=‘teacher‘; 2、select name,age from employee where post=‘teacher‘and age>30; 3、select name,age,salary from employee where post=‘teacher‘and salary between 9000 and 10000; 4、select * from employee where post_comment is not null; 5、select name,age,salary from employee where post=‘teacher‘and salary in(10000,9000,30000); 6、select name,age,salary from employee where post=‘teacher‘and salary not in(10000,9000,30000); 7、select name,age,salary from employee where post=‘teacher‘ and name like ‘jin%‘;
五 分组查询:group by
一、什么是分组?为什么要分组?
#1、首先明确一点:分组发生在where之后,即分组是基于where之后得到的记录而进行的 #2、分组指的是:将所有巨鹿按照某个相同字段进行归类,比如针对员工信息表的职位分组,或者按照性别进行分组等 #3、为什么要分组? 取每个部门的最高工资 取每个部门的员工数 取男人数和女人数 小窍门:’每’这个字后面的字段,就是我们分组的依据 4、大前提: 可以按照任意字段分组,但是分组完毕后,比如group by post,只能查看post字段,如果想看组内信息,需要借助于聚合函数。
二 ONLY_FULL_GROUP_BY
#查看MySQL 5.7默认的sql_mode如下: mysql> select @@global.sql_mode; ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION #!!!注意 ONLY_FULL_GROUP_BY的语义就是确定select target list中的所有列的值都是明确语义,简单的说来,在ONLY_FULL_GROUP_BY模式下,target list中的值要么是来自于聚集函数的结果,要么是来自于group by list中的表达式的值。 #设置sql_mole如下操作(我们可以去掉ONLY_FULL_GROUP_BY模式): mysql> set global sql_mode=‘STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION‘; !!!SQL_MODE设置!!!
mysql> select @@global.sql_mode; +-------------------+ | @@global.sql_mode | +-------------------+ | | +-------------------+ row in set (0.00 sec) mysql> select * from emp group by post; +----+------+--------+-----+------------+----------------------------+--------------+------------+--------+-----------+ | id | name | sex | age | hire_date | post | post_comment | salary | office | depart_id | +----+------+--------+-----+------------+----------------------------+--------------+------------+--------+-----------+ | 14 | 张野 | male | 28 | 2016-03-11 | operation | NULL | 10000.13 | 403 | 3 | | 9 | 歪歪 | female | 48 | 2015-03-11 | sale | NULL | 3000.13 | 402 | 2 | | 2 | alex | male | 78 | 2015-03-02 | teacher | NULL | 1000000.31 | 401 | 1 | | 1 | egon | male | 18 | 2017-03-01 | 老男孩驻沙河办事处外交大使 | NULL | 7300.33 | 401 | 1 | +----+------+--------+-----+------------+----------------------------+--------------+------------+--------+-----------+ rows in set (0.00 sec) #由于没有设置ONLY_FULL_GROUP_BY,于是也可以有结果,默认都是组内的第一条记录,但其实这是没有意义的 mysql> set global sql_mode=‘ONLY_FULL_GROUP_BY‘; Query OK, 0 rows affected (0.00 sec) mysql> quit #设置成功后,一定要退出,然后重新登录方可生效 Bye mysql> use db1; Database changed mysql> select * from emp group by post; #报错 ERROR 1055 (42000): ‘db1.emp.id‘ isn‘t in GROUP BY mysql> select post,count(id) from emp group by post; #只能查看分组依据和使用聚合函数 +----------------------------+-----------+ | post | count(id) | +----------------------------+-----------+ | operation | 5 | | sale | 5 | | teacher | 7 | | 老男孩驻沙河办事处外交大使 | 1 | +----------------------------+-----------+ rows in set (0.00 sec)
三 group by
单独使用group by关键字分组 select post from employee group by post; 注意:我们按照post字段分组,那么select查询的字段只能是post,想要获取组内的其他相关信息,需要借助函数 group by关键字和group_concat()函数一起使用 select post,group_concat(name) from employee group by post; #按照岗位分组,并查看组内成员名 select post,group_concat(name) names from employee group by post; group by与聚合函数一起使用 select post,count(id) as count from employee group by post;#按照岗位分组,并查看每个组有多少人
强调:
如果我们用unique的字段作为分组的依据,则每一条记录自成一组,这种分组没有意义
多条记录之间的某个字段值相同,该字段通常用来作为分组的依据
四 聚合函数
#强调:聚合函数聚合的是组的内容,若是没有分组,则默认一组 示例: select count(*) from employee; select count(*)from employee where depart_id=1; select max(salary)from employee; select min(salary)from employee; select avg(salary)from employee; select sum(salary)from employee; select sum(salary)from employee where depart_id=3;
五 小练习:
1. 查询岗位名以及岗位包含的所有员工名字 2. 查询岗位名以及各岗位内包含的员工个数 3. 查询公司内男员工和女员工的个数 4. 查询岗位名以及各岗位的平均薪资 5. 查询岗位名以及各岗位的最高薪资 6. 查询岗位名以及各岗位的最低薪资 7. 查询男员工与男员工的平均薪资,女员工与女员工的平均薪资
1、select post,group_concat(name) from employee group by post; 2、select post,count(name) from employee group by post; 3、select sex,count(id) from employee group by sex; 4、select post,avg(salary) from employee group by post; 5、select post,max(salary) from employee group by post; 6、select post,min(salary) from employee group by post; 7、select sex,avg(salary) from employee group by sex;
六、having过滤
having与where不一样的地方在于!!!!!
#!!!执行优先级从高到低:where > group by > having #1. Where 发生在分组group by之前,因而Where中可以有任意字段,但是绝对不能使用聚合函数。 #2. Having发生在分组group by之后,因而Having中可以使用分组的字段,无法直接取到其他字段,可以使用聚合函数
mysql> select @@sql_mode; +--------------------+ | @@sql_mode | +--------------------+ | ONLY_FULL_GROUP_BY | +--------------------+ row in set (0.00 sec) mysql> select * from emp where salary > 100000; +----+------+------+-----+------------+---------+--------------+------------+--------+-----------+ | id | name | sex | age | hire_date | post | post_comment | salary | office | depart_id | +----+------+------+-----+------------+---------+--------------+------------+--------+-----------+ | 2 | alex | male | 78 | 2015-03-02 | teacher | NULL | 1000000.31 | 401 | 1 | +----+------+------+-----+------------+---------+--------------+------------+--------+-----------+ row in set (0.00 sec) mysql> select * from emp having salary > 100000; ERROR 1463 (42000): Non-grouping field ‘salary‘ is used in HAVING clause mysql> select post,group_concat(name) from emp group by post having salary > 10000;#错误,分组后无法直接取到salary字段 ERROR 1054 (42S22): Unknown column ‘salary‘ in ‘having clause‘ mysql> select post,group_concat(name) from emp group by post having avg(salary) > 10000; +-----------+-------------------------------------------------------+ | post | group_concat(name) | +-----------+-------------------------------------------------------+ | operation | 程咬铁,程咬铜,程咬银,程咬金,张野 | | teacher | 成龙,jinxin,jingliyang,liwenzhou,yuanhao,wupeiqi,alex | +-----------+-------------------------------------------------------+ rows in set (0.00 sec)
小练习
1. 查询各岗位内包含的员工个数小于2的岗位名、岗位内包含员工名字、个数 3. 查询各岗位平均薪资大于10000的岗位名、平均工资 4. 查询各岗位平均薪资大于10000且小于20000的岗位名、平均工资
1、select post,group_concat(name),count(id) from employee group by post having count(id)<2; 2、select post,avg(salary) from employee group by post having avg(salary) >10000; 3、select post,avg(salary) from employee group by post having avg(salary) between 10000 and 20000;
七 查询排列:order by
按单列排序 select * from employee order by salary; select * from employee order by salary asc; select * from employee order by salary desc; 按多列排序:先按照age排序,如果年纪相同,则按照薪资排序 select * from employee order by age,salary desc;
小练习
1. 查询所有员工信息,先按照age升序排序,如果age相同则按照hire_date降序排序 2. 查询各岗位平均薪资大于10000的岗位名、平均工资,结果按平均薪资升序排列 3. 查询各岗位平均薪资大于10000的岗位名、平均工资,结果按平均薪资降序排列
1、select * from employee order by age,hire_date desc; 2、select post,avg(salary) from employee group by post having avg(salary)>10000 order by avg(salary) ;
八、限制查询的记录数:limit
示例: select * from employee order by salary desc limit 3; #默认初始位置为0 select * from employee order by salary desc limit 0,5; #从第0开始,即先查询出第一条,然后包含这一条在内往后查5条 select * from employee order by salary desc limit 5,5; #从第5开始,即先查询出第6条,然后包含这一条在内往后查5条
#1、分页显示,每页显示5条 select * from employee limit 0,5; select * from employee limit 5,5; select * from employee limit 10,5;
九、正则表达式
select * from employee where name regexp ‘^ale‘; select * from employee where name regexp ‘on$‘; select * from employee where name regexp ‘m{2}‘; 小结:对字符串匹配的方式 where name=‘egon‘; where name like ‘yua%‘; where name regexp ‘on$‘;
小练习
查看所有员工中名字是jin开头,n或者g结尾的员工信息 select * from employee where name regexp ‘^jin.*[ng]$‘ ;
标签:column 技术 base select 连接字符串 第一个 薪资 无法 直接
原文地址:http://www.cnblogs.com/llhtjwq/p/7732826.html