mysql 查询

联合查询

union 去重
union all 不去重

select username from cms_user UNION all select username from   cms_user;

子查询

定义:将一个查询语句嵌套在另外一个语句中
一个查询语句的结果是另外一个语句的查询条件

in exists 或者运算符

student表

CREATE TABLE student (
id SMALLINT UNSIGNED PRIMARY KEY auto_increment,
sname VARCHAR(20) NOT NULL,
score TINYINT UNSIGNED);

奖学金表

CREATE TABLE scholarship(
id TINYINT UNSIGNED PRIMARY KEY auto_increment,
level TINYINT UNSIGNED);

查询一等奖学金的学生信息
select id,username from student where score>(select level from scholarship where id=1);

exists

SELECT id,ename,depId FROM employee WHERE EXISTS
(SELECT * FROM department WHERE id=3);

any some all

当ALL和>或>=结合使用时,是获取最大值,和<或<=结合使用时,是获取最小值;
ANY正好和ALL相反;
SOME和ANY是相同的

#查询获得学金的学生的姓名和分数
SELECT sname,score FROM student WHERE score>=ANY
(SELECT level FROM scholarship);
#查询获得一等奖学金的学生的姓名和分数
SELECT sname,score FROM student WHERE score>=ALL
(SELECT level FROM scholarship);
#查询没有获得学金的学生的姓名和分数
SELECT sname,score FROM student WHERE score<ALL
(SELECT level FROM scholarship);
#查询没有获得一等奖学金的学生的姓名和分数
SELECT sname,score FROM student WHERE score<ANY
(SELECT level FROM scholarship);

正则表达式查询

^ 匹配字符开始的部分
select * from employee where username regexp ‘^k’;
$ 匹配结尾
select * from employee where username regexp ‘g$’;
. 任意字符
select * from employee where username regexp ‘q.’;
[] 字符集合
select * from employee where username regexp ‘[uo]’;
| 查看字符串中任意一个
select * from employee where username regexp ‘qu|ng’;
* 出现多次
+ 最少出现一次

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值