sql-DQL-单表查询
单表查询
select [distint]* 字段列表 from 表名列表 where 条件列表 group by 分组字段 having 分组之后的条件 order by 排序 limit 分页限定
基础查询
select * from emp;
1.查询多个列(控制列)
select 字段名1,字段名2... from 表名;
查询所有列
select * from emp; -- 如果查询所有字段,则可以使用*来替代字段列表。
select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp; -- 推荐使用第二种。列出所有列名
- 计算列
一般可以使用四则运算计算一些列的值。(一般只会进行数值型的计算)
select empno,ename,sal,sal*12 from emp;
empno ename sal sal*12
7369 SMITH 800 9600
- 起别名:as
select ename as "姓名",job as "工作" from emp;
-- as也可以省略
select ename "姓名",job "工作" from emp;
select ename 姓名 ,job 工作 from emp;
select ename "from" ,job 工作 from emp; -- 不推荐

- 去除重复:distinct
select distinct job as 工作,deptno as 部门编号 from emp ;

条件查询 where
范围查询
算数运算 加减乘除
null的计算
① a.null参与运算时,结果永远为null
select ename,sal,comm,sal*12+comm from emp;

oracle的解决方案 --> 使用 nvl (相当于if)
select ename,sal,comm,sal*12+nvl(comm,0) from emp;
额外:nvl2 (if…else…)
nvl2(a,b,c) 当a=null时候,返回c;否则返回b
select ename,sal,comm,sal*12+nvl2(comm,comm,0) from emp;

mysql的解决方案
ifnull(表达式1,表达式2):
- 表达式1:哪个字段需要判断是否为null
- 如果该字段为null后的替换值。
关系运算符
关系运算符 > < >= <= = !=(或<>)
如果是null,则使用is null或is not null.
判断null
② b. 判断null 不能 !=null;而必须使用 is not null /is null
select * from emp where comm=null; -- 错误
select * from emp where comm < 400 or comm IS NULL;

逻辑运算
mysql 中的逻辑运算符 and(或 &&) or(或 ||) not(或 !)
oracle 逻辑运算符 or and not
select * from emp where empno=7788 or empno=7369;
select * from emp where deptno=20 and job ='CLERK';
select * from emp where not ( empno=7788 or empno=7369 );
而 || 被oracle用于字符串拼接
- select 'hello'||'123' from dual ;
BETWEEN ... AND ...
between 小 and 大,(数字和日期)
数字
select * from emp where sal between 2000 and 3000
日期
oracle:日期默认格式 '01-1月-81'(date)
select * from emp where hiredate between '01-1月-81' and '10-11月-81' ;
mysql:日期默认格式 'yyyy-MM-dd'(datetime)
select * from emp where hiredate between '1981-1-01' and '1981-11-10';
IN(集合)/not in
select * from emp where comm in (0,300,500);

如果集合有null,可以in, 不能not in
错误示例: where deptno not in (10,20,null)
模糊查询 like
占位符(通配符)
_:单个任意字符
%:多个任意字符 0-N
查询姓名中 第二个字母是M的员工
select * from emp where ename like '_M%' ;
查询姓名长度>=6的员工。
select * from emp where ename like '______%' ;
转义符:
如果要匹配的ename就是A_B,就需要使用转义符
select * from emp where ename like 'A\_B' escape '\' ;
排序查询 order by
order by 排序字段1 排序方式1, 排序字段2 排序方式2
排序字段可以是 字段名|别名|表达式|数字
排序方式:
ASC:升序,默认的。
DESC:降序。
如果有多个排序条件,则当前边的条件值一样时,才会判断第二条件。
null排序
select * from emp ORDER BY comm asc;
在MySQL中 null最小,升序时 排在最前面

在Oracle中 null最大,升序时 排在最后面

如果排序存在null:在Oracle中Null最大。如果需要null排在最后,使用nulls last ;
…order by common nulls last;
Oracle/Sql Server :从1开始数
MySql:从0开始数
分组查询:group by ... having ...
group by 分组字段 having 筛选组
分组之后查询的字段:分组字段、聚合函数
查询时,不在组函数(多行函数)中的列,必须在group by后面
不能在where中使用组函数;可以在having中使用组函数(多行函数)
查询每个部门的人数:按部门分组
- select deptno, job,count(*) from emp group by deptno,job ;
查询每个部门的人数,只查询人数大于5的组
- select deptno,count(*) from emp group by deptno having count(*)>5 ;
可多个列分组(先按部门分组,再按job分组)
select deptno,job,avg(sal) from emp group by deptno,job;
分析:
select 分组1,分组2 ,组函数() from emp group by 分组1,分组2 ;
- where 和 having 的区别?
- 筛选 行:where
- 筛选 组:having
- where 在分组之前进行限定,如果不满足条件,则不参与分组。
having在分组之后进行限定,如果不满足结果,则不会被查询出来 - where 后不可以跟聚合函数,having可以进行聚合函数的判断。
- where 在分组之前进行限定,如果不满足条件,则不参与分组。
sql-DQL-单表查询的更多相关文章
- 06-查询操作(DQL)-单表查询
一. 综述 查询操作主要从两个方面来说:单表查询和多表查询. 单表查询包括:简单查询.过滤查询.结果排序.分页查询.聚集函数. 二 . 案例设计 1. 设计产品表(product).包括:主键 ...
- sql语句-单表查询
一:单表查询 CREATE TABLE `Score`( `s_id` ), `c_id` ), `s_score` ), PRIMARY KEY(`s_id`,`c_id`) ); ); ); ); ...
- 数据库——SQL数据单表查询
数据查询 语句格式 SELECT [ALL|DISTINCT] <目标列表达式> [,<目标列表达式>] … FROM <表或视图名>[,<表或视图名&g ...
- (七)MySQL数据操作DQL:单表查询1
(1)单表查询 1)环境准备 mysql> CREATE TABLE company.employee5( id int primary key AUTO_INCREMENT not null, ...
- DQL单表查询
DQL数据查询语言数据查询关键字:select 对数据库关系表中的数据进行查询 创建数据库创建表格学生表(学号s_no,姓名s_name,班级s_classno,课程s_courseno) 班级表(班 ...
- 【T-SQL基础】01.单表查询-几道sql查询题
概述: 本系列[T-SQL基础]主要是针对T-SQL基础的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础]02.联接查询 [T-SQL基础]03.子查询 [T-SQL基础 ...
- SQL基本查询_单表查询(实验二)
SQL基本查询_单表查询(实验二) 查询目标表结构及数据 emp empno ename job hiedate sal comn deptno 1007 马明 内勤 1992-6-12 4000 2 ...
- springdata 查询思路:基本的单表查询方法(id,sort) ---->较复杂的单表查询(注解方式,原生sql)--->实现继承类---->复杂的多表联合查询 onetomany
springdata 查询思路:基本的单表查询方法(id,sort) ---->较复杂的单表查询(注解方式,原生sql)--->实现继承类---->复杂的多表联合查询 onetoma ...
- sql多表查询(单表查询略过)
表library: 表borrow: 表reader: 1.等值连接:(常用) 原理:将多张表组合成一个逻辑大表,即字段相加记录相乘(笛卡尔积). 语法:select * from 表A,表B whe ...
- SQL数据查询之——单表查询
一.SQL数据查询的一般格式 数据查询是数据库的核心操作.SQL提供了SELECT语句进行数据查询,其一般格式为: SELECT [ALL | DISTINCT]<目标列表达式>[,< ...
随机推荐
- eBPF Cilium实战(2) - 底层网络可观测性
在之前的平台中,对于组件之间的网络流向不具备直接的可观测性,用户组件间通信出现问题,只能通过传统命令行工具进行手动排查,而 cilium 的 Hubble 服务可以提供 UI 界面向用户展示实时的流量 ...
- JavaScript学习总结5-作用域
由于所有的全局变量都会绑定到window上,如果不同的JS文件,使用了相同的全局变量,会造成冲突,可以把自己的代码全部放入及定义的唯一空间中,减少全局命名冲突问题
- ctx.createCircularGradient is not a function
正确 const grd = ctx.createCircularGradient(75, 50, 50) grd.addColorStop(0, 'red') grd ...
- python 包之 redis 数据库操作教程
一.安装 redis 是一个 Key-Value 数据库 Value 支持 string(字符串),list(列表),set(集合),zset(有序集合),hash(哈希类型)等类型 pip inst ...
- 史上最全log4j2远程命令执行漏洞汇总报告
已投稿信安之路公众号,文章链接
- 『现学现忘』Git基础 — 7、设置Git Bash终端默认路径
目录 1.Git Bash默认路径 2.如何查看Git Bash终端默认路径 3.如何修改Git Bash终端的默认路径 4.拓展:指定目录进入Git Bash终端 5.注意事项 如果您不熟悉Git命 ...
- oracle split 以及 简单json解析存储过程
BEGIN; 由于之前工作上需要在oracle中做split功能以及json格分解.然后经过一番google和优化整合,最后整理到一个存储过程包中,易于管理,代码如下: 1.包定义: CREATE O ...
- 《计算机组成原理/CSAPP》网课总结(二)——编译原理基础
这部分是四月份的安排,拖到五一放假了,主要是对源码编译过程的一次总结,总的来说,大致可分为预编译.编译.汇编和链接四部分.这里简单记录一下: 一 概述 1.预处理 或者说是预编译,指的是在编译前需要做 ...
- 以rem为单位,数值较小,border-radius:50%部分浏览器渲染不圆方法
元素使用rem做单位且较小时,对于border-radius:50%在部分浏览器不圆解决方法: 1.将原来宽高扩大至两倍(.1rem --> .2rem),再使用transform:scale( ...
- HamsterBear Linux Low Res ADC按键驱动的适配 + LVGL button移植
HamsterBear lradc按键驱动的适配 平台 - F1C200s Linux版本 - 5.17.2 ADC按键 - 4 KEY tablet 驱动程序位于主线内核: drivers/inpu ...