文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL的查询操作

2024-04-02 19:55

关注

1. 基础的查询操作

#简单查询
select * from emp;   //查询emp中所有的记录
select empno, job,ename from emp;  //查询emp表中的某些字段
select ename as 名字 from emp;   //使用字段别名

去重 distinct

select distinct deotno from emp; //去除重复的行(针对字段而言)

排序 order by

#默认是升序(asc),降序(desc)
select  *  from emp order by sal desc;    //以工资按降序排序
select  *  from epm order by sal , deptno  //多字段排序
select  sal*12  annsal  from epm order by annsal   //别名排序

条件查询 where

select  *  from emp where sal>1000;   //工资大于1000的
select  *  from emp where sal>1000  and  sal<2000;
select  *  from emp where sal>5000  or  sal<1000
select  *  from emp where sal<>2500   //工资不等于2500
select  *  from emp where sal  is null   //工资不空的
select  *  from emp where sal>0 or 1=1;  //恒等式

ps:运算符的优先级:算术>连接>比较>逻辑

分组查询(group by)
描述:将表中的数据分成若干个小组
语法:select 字段 from where 条件 group by 字段 order by 字段

#例:
select 字段 from where 条件 group by 字段 order by 字段
ps:在group  by 分组,select 子句,不能写group by没有的字段。除非这些字段用在聚合函数中

过滤 having
描述:过滤分组之后的结果,只能出现在group by 的后面

#例:
select deptno , count(1),avg(sal) from emp group by deptno having avg(sal) >2000
select avg(sal) avg_sal,deptno from emp group by deptno having  avg_sal>2000;

执行过程:from –where –group by --- having –select ---order by
分页

#例:
select * from emp limit 0 , 5 ;  //从第1行开始取,取5行

模糊查询

例:
select * from emp where ename like 's%'
ps:
%:表示0~多个任意字符
_:表示1个任意字符

2. 内连接与外连接

(1)内连接:

#语法:
select  table1.column,table2.column from table1,table2 where table1.column= table2.column
select dept.DEPTNO,ename ,dname from emp inner join dept on emp.DEPTNO =dept.DEPTNO
select emp.ename,dept.dname from emp inner join dept using(deptno)

注意:一般的如果两张表示通过外键连接的,使用第1,2种查询方法,如果不是外键连接的使用1种查询方法。第3中方式的using中填入,两张表中字段名称相同的字段,而且通用列字段只出现一次(即去除重复的字段)
内连接的特点

3. 子查询

语法:select 字段 from table where 表达式 operator (子查询字段)。
特点:子查询在主查询前执行一次,主查询使用子查询的结果
使用
  - 单行子查询:如果使用子查询的结果是1行,可以使用比较运算符(> < <>)
  - 多行子查询:如果使用子查询的结果是多行,则 all 、any in
  - exists:select from dept e where exists (select from emp e1 where sal>2000 and e1.deptno=e.deptno)
in和exists的区别
  - in:先执行子查询,将结果返回给主查询,主查询继续执行
  - 先执行主查询,将主查询的值依次在子查询进行匹配,根据是否匹配返回true或者false,如果是true连接展示,否则不展示。
子查询和关联查询的使用时机
  - 子查询:查询条件和结果放在同一张表中
  - 关联查询,查询条件和结果分布在多张表中

3. 联合查询

关键字:union、union all。
区别
  - union:会发生去重
  - union all:不会发生去重
用法

#例:
select * from emp where sal>2000 union select * from emp where deptno>20
select * from emp where sal>2000 union all select * from emp where deptno>20

使用要求:联合的结果集必须一致(两张表一致,查询的字段也一致),不然会发生错误。

关于sql的交集、差集、并集:
MySQL的查询操作

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯