源无极

导航

 

一、

建员工表 : d_id   是部门  id

 

1.多字段进行排序,薪资一样,名字按字典顺序排

 

 

2.limit的使用

语法

limit  [位置偏移量]  行数。 位置偏移量:就是从哪行开始显示,第一条记录是0,第二条为1,...

 

连接查询

(一)内连接 查询

使用比较运算符进行表之间某些列数据的比较操作,并列出这些表中与连接条件相匹配的数据行,组成新

的记录,就是只有满足条件的列才会出现在结果列表中

 

建部门表department

 

1.employee 和department 两个表有共同的字段d_id 可以建立连接,使用内连接查询

 

2.使用INNER JOIN 语句  和上面一样的效果

 

 

 

3. 如果一个连接查询中涉及到的表是同一张表,那就是自连接查询

查询e_id=1的员工在的部门中所有员工的编号。

 

 

 

左外连接查询

 

1.查询所有员工所在部门,没有部门也列出。

 

 

 

 

 

 

右外连接查询

 

 

 

复合条件连接诶查询

 

1.使用INNER JOIN  查询employee 中部门编号为1001的客户名称

 

 

 子查询

exists关键字的子查询

exists后面的是任意的子查询,系统对子查询进行运算以判断它是否返回行,如果至少返回一行,则exists返回为true

此时外层查询语句将进行查询反之,exists发回false,则外层语句将不进行查询。

 

1. 查询department中是否存在d_id=1007的员工,如果存在查询employee表的员工。

 

 

 2.not exists和上面相反,原理一样

 

 

 

 

合并查询

UNION   和UNION  ALL

使用union关键字可以给出多条select语句,并将它们的结果合成单个结果集,合并时两个表对应的列数和数据类型必须相同,

个select之间用union或是union all 相隔离,union 没有all时,执行的时候会删除重复的记录,所有返回的都是唯一的,

有all 的话,不删除重复,且不对结果进行排序。

1. 查询所有工资小于5000的员工信息,查询d_id等于1001和1003的所有员工信息使用UNION连接查询。

 

先看所有工资小于5000的员工信息的数据

 

 

 查询d_id等于1001和1003的所有员工信息

 

 

 用union  

 

 

 

 

 

2.使用UNION ALL 

 

 正则表达式

mysql使用regexp 关键字指定正则表达式的字符匹配模式,以下列出regexp操作符后常用的匹配字符

 

 

1.查询employee中,e_name以黄子开头的员工

 

 

2.查询employee中,e_name以龙字结束的员工

 

 

3.为了达到效果重新建emp表

 

 

 查询emp中name里面有i 和a两个字母之间只有一个字母的记录。

 

 

4. 查询name中,以字母x开头,且x后出现字母 i 的记录

 

 

 

 

 

 因为*是匹配零次或是多次,所以x后没有i也会匹配

 

5.4.查询name中,以字母x开头,且x后出现字母 i 至少一次的记录

 

 

 

 

6..查询name中,包含en的名字

 

 

 

 

7. 查询name中,包含en或是ao的名字 :会删除重复的项

 

 

 

8. 用like查询name字段中包含en 的名字

 

 

 9.数据库添加mao这个名字,查询名字中包含m或o,或是两者都有的名字

 

 

 

 10.查询id字段中包含2或是3,或是4的情况  

 

 

 也可以写成[234]

 

 10.查询id字段中包含2,3以外的情况  

 

 

 11.查询name中字母 i至少出现一次的情况

 

 

 

总结:regexp和like

当like 查询以包含en字母的时,like ‘%en%’ ,这样的情况,regexp和 like一样的效果。

关于LIKE和REGEXP的区别:LIKE匹配整个列。如果被匹配的文本仅在列值中出现,LIKE并不会找到它,

相应的行也不会返回(当然,使用通配符除外)。而REGEXP在列值内进行匹配,如果被匹配的匹配的文本在列值中出现,

REGEXP将会找到它,相应的行将被返回,这时一个非常重要的差别(当然,如果适应定位符号^和$,可以实现REGEXP匹配整个列而不是列的子集)。
关于大小写的区分:MySQL中正则表达式匹配(从版本3.23.4后)不区分大小写 。

如果要区分大小写,应该使用BINARY关键字,如where post_name REGEXP BINARY 'Hello .000'

 

posted on 2019-10-04 00:25  源无极  阅读(161)  评论(0编辑  收藏  举报