MySQL学习笔记4——DQL
DQL(数据查询语言)
一、基本查询
1.字段(列)控制
1)查询所有列
SELECT * FROM 表名;
->"*"表示查询所有列
2)查询指定列
SELECT 列1 [, 列2,..., 列n] FROM 表名;
3)让完全重复的记录只显示一次
当查询结果中的多行记录一模一样时,只显示一行。一般查询所有列时很少会有这种情况,但只查询一列或几列时,就有可能发生。
SELECT DISTINCT *|列1 [, 列2,..., 列n] FROM 表名;
SELECT DISTINCT sal FROM emp;
->查询员工表的工资,如果存在相同的工资只显示一次。
4)列运算
1.数量类型的列可以做加、减、乘、除运算
SELECT sal*1.5 FROM emp;
SELECT sal+comm FROM emp;
2.字符串类型可以做连续运算
SELECT CONCAT('$', sal) FROM emp;
3.转换NULL值
有时需要把NULL转换成其他值,例如com+1000时,如果com列存在NULL值,那么NULL+1000还是NULL,而我们这时希望把NULL当成0来运算。
SELECT IFNULL(comm, 0)+1000 FROM emp;
->IFNULL(comm, 0):如果comm中存在NULL值,那么当成0来运算。
4.给列起别名
一般在使用列运算后,会得到一个新的列,我们可以给这个列起一个别名
SELECT IFNULL(comm, 0)+1000 AS 奖金 FROM emp;
->AS可以省略
2.条件控制
1)条件查询
与之前介绍的UPDATE和DELETE语句一样,SELECT语句也可以使用WHERE子句来控制查询记录。
*SELECT empno, ename, sal, comm, FROM emp WHERE sal > 10000 AND comm IS NOT NULL;
->查询emp表列empno, ename, sal, comm其中sal大于10000且comm不为NULL的记录。
*SELECT empno, ename, sal FROM emp WHERE sal BETWEEN 20000 AND 30000;
->查询emp表列empno, ename, sal其中sal在20000到30000之间的记录。
SELECT empno, ename, job FROM emp WHERE job IN ('经理', '董事长');
->查询emp表列empno, ename, job其中job在('经理', '董事长')集合中的记录。
2)模糊查询
当你想查询姓张,并且名字一共两个字的员工时,可以使用模糊查询。
*SELECT * FROM emp WHERE ename LIKE '张_';
->模糊查询需要使用运算符:LIKE,其中'_'用来匹配一个任意字符,注意只能匹配一个字符而不是多个。
->上面语句查询的是姓张,名字由两个字组成的员工记录。
*SELECT * FROM emp WHERE ename LIKE '张__';
->查询的是姓张,名字由三个字组成的员工记录。
如果想查询姓张,名字几个字都可以的员工可以使用'%'。
*SELECT * FROM emp WHERE ename LIKE '张%';
->其中'%'匹配0~N个任意字符,所以上面的语句查询的是姓张的所有员工。
*SELECT * FROM emp WHERE ename LIKE '%小%';
->这条语句,小明,小红,小,张小都可以查询到,因为'%'匹配0~N个任意字符。
*SELECT * FROM emp WHERE ename LIKE '%';
->这个条件等同于不存在,但如果姓名为NULL的查询不出来。
二、排序
1.升序
SELECT * FROM WHERE emp ORDER BY sal ASC;
->按sal升序排序
->其中ASC可以省略
2.降序
SELECT * FROM WHERE emp ORDER BY comm DESC;
->按comm降序排序
->其中DESC不能省略
3.使用多列作为排序条件
SELECT * FROM WHERE emp ORDER BY sal ASC, comm DESC;
->使用sal升序排序,如果存在sal相同时,使用comm降序排序
三、聚合函数
聚合函数用来做某列的纵向运算。
1.COUNT
SELECT COUNT(*) FROM emp;
->计算emp表中所有列都不为NULL的记录的行数
SELECT COUNT(comm) FROM emp;
->计算emp表中comm列不为NULL的记录的行数
2.MAX
SELECT MAX(sal) FROM emp;
->查询最高工资
3.MIN
SELECT MIN(sal) FROM emp;
->查询最高工资
4.SUM
SELECT SUM(sal) FROM emp;
->查询工资和
5.AVG
SELECT AVG(sal) FROM emp;
->查询平均工资
四、分组查询
分组查询是把记录使用某一列进行分组,然后查询组信息。
例如:查看所有部门的记录数。
SELECT deptno, COUNT(*) FROM emp GROUP BY deptno;
->使用deptno分组,查询部门编号和每个部门的记录数
SELECT job, MAX(sal) FROM emp GROUP BY job;
->使用job分组,查询每种工作的最高工资
组条件
以部门分组,查询每组记录数,条件为记录数大于3
SELECT deptno, COUNT(*) FROM emp GROUP BY deptno HAVING COUNT(*)>3;
五、limit子句
LIMIT用来限定查询结果的起始行,以及总行数。
例如:查询起始行为第5行,一共查询3行记录
SELECT * FROM emp LIMIT 4, 3;
->其中4表示从第5行开始,3表示一共查询3行,即第5, 6, 7行记录。
MySQL学习笔记4——DQL的更多相关文章
- MySql学习笔记(一)之DQL常用查询
MySql学习笔记(一)之DQL常用查询 前言:mysql是中小型的数据库软件,SQL语言分为DDL,DCL,DML,DQL四种,在这里重点讲解DQL的单表查询. 正文:在学习mysql单表查询之前, ...
- Mysql学习笔记(三)对表数据的增删改查。
正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...
- MySQL学习笔记一
MySQL 学习笔记 一 一.数据库简单介绍 1. 按照数据库的发展时间顺序,主要出现了以下类型数据库系统: Ø 网状型数据库 Ø 层次型数据库 Ø 关系型数据库 Ø 面向对象数据库 上面4中数据库系 ...
- Mysql学习笔记(二)数据类型 补充
原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与 ...
- Mysql学习笔记(一)数据类型
原文:Mysql学习笔记(一)数据类型 学习内容: Mysql基本数据类型. 1.数字类型.. i.整型 Mysql数据类型 含义(有符号) tinyint(m ...
- 初识mysql学习笔记
使用VMVirtualBox导入Ubuntu后,可以通过sudo apt-get install mysql-server命令下载mysql. 在学习过程中,我遇到了连接不上Xshell的问题.最终在 ...
- MySQL学习笔记-锁相关话题
在事务相关话题中,已经提到事务隔离性依靠锁机制实现的.在本篇中围绕着InnoDB与MyISAM锁机制的不同展开,进而描述锁的实现方式,多种锁的概念,以及死锁产生的原因. Mysql常用存储引擎的锁 ...
- MySQL学习笔记-事务相关话题
事务机制 事务(Transaction)是数据库区别于文件系统的重要特性之一.事务会把数据库从一种一致状态转换为另一个种一致状态.在数据库提交工作时,可以确保其要么所有修改都已经保存了,要么所有修改都 ...
- MySQL学习笔记-数据库文件
数据库文件 MySQL主要文件类型有如下几种 参数文件:my.cnf--MySQL实例启动的时候在哪里可以找到数据库文件,并且指定某些初始化参数,这些参数定义了某种内存结构的大小等设置,还介绍了参数类 ...
随机推荐
- CSS中层叠和继承的概念。
继承 CSS的某些样式是具有继承性的,那么什么是继承呢?继承是一种规则,它允许样式不仅应用于某个特定html标签元素,而且应用于其后代.比如下面代码: 1 2 3 4 5 6 7 8 9 <ht ...
- ASM与ASMD
时序机 状态机 控制器 数据通路之间的关系 样例代码
- 使用 github pages快速部署自己的静态网页
看见很多大神在Github Pages上部署Demo,感觉效果还不错,刚才自己也试了一下,发现其实并不难! 选择 github pages 的理由 使用零成本: github pages 集成在 gi ...
- mysql--事务详解
事务的四大特性: # 原子性(atomicity) 一个事务必须被视为一个不可分割的最小工作单元,整个事务中的所有操作要么全部提交成功,要么全部失败回滚,对于一个事务来说,不可能只执行其中的一部分操作 ...
- 【STM32H7教程】第15章 STM32H7的GPIO基础知识(重要)
完整教程下载地址:http://www.armbbs.cn/forum.php?mod=viewthread&tid=86980 第15章 STM32H7的GPIO基础知识(重要) ...
- Unity BehaviorDesigner行为树基础总结
BehaviorDesigner——行为树,用于控制和实现AI逻辑,类似于这样: 上面这个行为树实现了这样的逻辑: 当Player有Input时按照Input值来移动,无Input时查找最近的可攻击目 ...
- 【Linux】文本处理工具介绍
文本处理工具介绍 grep.sed和awk都是文本处理工具,各自都有各自的优缺点,一种文本处理命令是不能被另一个完全替换的.相比较而言,sed和awk功能更强大,且已独立成一种语言来介绍. grep: ...
- app——升级测试点
APP版本升级的测试点 该文章转载于:https://www.cnblogs.com/changpuyi/p/8618755.html 移动端版本更新升级是一个比较重要的功能点,主要分为强制更新和 ...
- virtualbox FAIL(0x80004005) VirtualBox VT-x is not available (VERR_VMX_NO_VMX)
virtualbox启动虚拟机报错: FAIL(0x80004005) VirtualBox VT-x is not available (VERR_VMX_NO_VMX),无法创建新任务 这是win ...
- 安装v2sora@y
v2r@y安装 1. 安装nginx 这儿使用tengine进行安装, 可以看以前的博客 1.1) 注意带 http_v2 编译 ./configure --with-http_v2_module 不 ...