当前位置: 首页 > news >正文

DQL操作(数据库表数据查询操作)

DQL数据查询语言

数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。

查询返回的结果集是一张虚拟表。

查询关键字:SELECT 语法:

 SELECT 列名 FROM表名

【WHERE --> GROUP BY -->HAVING--> ORDER BY-->LIMIT】

语法:

SELECT selection_list /*要查询的列名称*/

FROM table_list /*要查询的表名称*/

WHERE condition /*行条件*/

GROUP BY grouping_columns /*对结果分组*/

HAVING condition /*分组后的行条件*/

ORDER BY sorting_columns /*对结果分组*/

LIMIT offset_start, row_count /*结果限定*/

以该案例分析查询语句:

#创建数据库Study
CREATE DATABASE Study
#使用数据库Study
USE Study

#创建表stu
CREATE TABLE `stu` (
`sid`	CHAR(6),
`sname`	VARCHAR(50),
`age`	INT,
`gender`VARCHAR(50)
);

#向stu表中插入数据
INSERT INTO stu VALUES('S_1001', 'liuYi', 35, 'male');
INSERT INTO stu VALUES('S_1002', 'chenEr', 15, 'female');
INSERT INTO stu VALUES('S_1003', 'zhangSan', 95, 'male');
INSERT INTO stu VALUES('S_1004', 'liSi', 65, 'female');
INSERT INTO stu VALUES('S_1005', 'wangWu', 55, 'male');
INSERT INTO stu VALUES('S_1006', 'zhaoLiu', 75, 'female');
INSERT INTO stu VALUES('S_1007', 'sunQi', 25, 'male');
INSERT INTO stu VALUES('S_1008', 'zhouBa', 45, 'female');
INSERT INTO stu VALUES('S_1009', 'wuJiu', 85, 'male');
INSERT INTO stu VALUES('S_1010', 'zhengShi', 5, 'female');
INSERT INTO stu VALUES('S_1011', 'xxx', NULL, NULL);

#创建表emp
CREATE TABLE emp(
	empno		INT,
	ename		VARCHAR(50),
	job		VARCHAR(50),
	mgr		INT,
	hiredate	DATE,
	sal		DECIMAL(7,2),
	comm		DECIMAL(7,2),
	deptno		INT
) ;

#向emp表中插入数据
INSERT INTO emp VALUES(7369,'SMITH','CLERK',7902,'1980-12-17',800,NULL,20);
INSERT INTO emp VALUES(7499,'ALLEN','SALESMAN',7698,'1981-02-20',1600,300,30);
INSERT INTO emp VALUES(7521,'WARD','SALESMAN',7698,'1981-02-22',1250,500,30);
INSERT INTO emp VALUES(7566,'JONES','MANAGER',7839,'1981-04-02',2975,NULL,20);
INSERT INTO emp VALUES(7654,'MARTIN','SALESMAN',7698,'1981-09-28',1250,1400,30);
INSERT INTO emp VALUES(7698,'BLAKE','MANAGER',7839,'1981-05-01',2850,NULL,30);
INSERT INTO emp VALUES(7782,'CLARK','MANAGER',7839,'1981-06-09',2450,NULL,10);
INSERT INTO emp VALUES(7788,'SCOTT','ANALYST',7566,'1987-04-19',3000,NULL,20);
INSERT INTO emp VALUES(7839,'KING','PRESIDENT',NULL,'1981-11-17',5000,NULL,10);
INSERT INTO emp VALUES(7844,'TURNER','SALESMAN',7698,'1981-09-08',1500,0,30);
INSERT INTO emp VALUES(7876,'ADAMS','CLERK',7788,'1987-05-23',1100,NULL,20);
INSERT INTO emp VALUES(7900,'JAMES','CLERK',7698,'1981-12-03',950,NULL,30);
INSERT INTO emp VALUES(7902,'FORD','ANALYST',7566,'1981-12-03',3000,NULL,20);
INSERT INTO emp VALUES(7934,'MILLER','CLERK',7782,'1982-01-23',1300,NULL,10);

#创建表dept
CREATE TABLE dept(
	deptno		INT,
	dname		VARCHAR(14),
	loc		VARCHAR(13)
);

#向dept表中插入数据
INSERT INTO dept VALUES(10, 'ACCOUNTING', 'NEW YORK');
INSERT INTO dept VALUES(20, 'RESEARCH', 'DALLAS');
INSERT INTO dept VALUES(30, 'SALES', 'CHICAGO');
INSERT INTO dept VALUES(40, 'OPERATIONS', 'BOSTON');

1.基础查询

查询所有字段

查询表中的所有字段:第一种方式将所有的字段一一写出来,第二种,使用*表示所有的字段

SELECT * FROM 表名;

查询指定字段

SELECT 字段名1,字段名2,......字段名n FROM 表名;

2.条件查询

条件查询就是对查询出来的结果进行筛选,使用WHERE进行过滤

在WHERE子句中可以使用如下运算符及关键字:

  1. =、!=、<>、<、<=、>、>=;
  2. BETWEEN…AND;
  3. IN(set);
  4. IS NULL;IS NOT NULL:  
  5. AND;
  6. OR;
  7. NOT;

 

#查询性别为女,并且年龄小于50的记录(记录:表示查询所有的字段)
SELECT * FROM stu WHERE gender ='female' AND age<50
#查询学号为S_1001,或者姓名为liSi的记录
SELECT * FROM stu WHERE sid = 's_1001' OR sname ='lisi';
#查询学号为S_1001,S_1002,S_1003的记录
SELECT * FROM stu WHERE sid ='s_1001' OR sid = 's_1002' OR sid='s_1003';
#使用IN关键字实现上述需求
SELECT * FROM stu WHERE sid IN('S_1001','S_1002','S_1003');

#查询学号不是S_1001,S_1002,S_1003的记录
SELECT * FROM stu WHERE sid NOT IN('S_1001','S_1002','S_1003');
SELECT * FROM stu WHERE sid !='s_1001' AND sid != 's_1002' AND sid!='s_1003';
#查询年龄为null的记录
SELECT * FROM stu WHERE age IS NULL;
#查询年龄在20到40之间的学生记录
SELECT *FROM stu WHERE age>=20 AND age <=40;
#使用BETWEEN AND关键字来实现
SELECT * FROM stu WHERE age BETWEEN 20 AND 40; #包含20和40两个临界值

#查询性别非男的学生记录
#非男就是女,查询性别为女的学生记录
SELECT * FROM stu WHERE gender='female';
SELECT * FROM stu WHERE gender!='male';
SELECT * FROM stu WHERE gender <>'male';
SELECT * FROM stu WHERE NOT gender ='male';#注意:NOT需要写在字段名的前面
#查询姓名不为null的学生记录
SELECT * FROM stu WHERE sname IS NOT NULL;
SELECT * FROM stu WHERE NOT sname IS NULL;

3.模糊查询

当想查询姓名中包含a字母的学生时就需要使用模糊查询

模糊查询需要使用关键字LIKE

通配符:

下划线 _:表示任意一个字符;%表示任意0~n个字符

#查询姓名由5个字母构成的学生记录
SELECT * FROM  stu WHERE sname LIKE'_____';
#查询姓名由5个字母构成,并且第5个字母为“i”的学生记录
SELECT * FROM stu WHERE sname LIKE'____i';
#查询姓名以“z”开头的学生记录
SELECT * FROM stu WHERE sname LIKE'z%';
#查询姓名中第2个字母为“i”的学生记录
SELECT * FROM stu WHERE sname LIKE'_i%';
#查询姓名中包含“a”字母的学生记录
SELECT * FROM stu WHERE sname LIKE'%a%';

4.字段控制查询

去除重复记录

去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的记录。当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用DISTINCT:

#通过emp表来查询一下员工所在的部门有哪些
SELECT deptno FROM emp;
#使用DISTINCT关键字去除重复记录
SELECT DISTINCT deptno FROM emp;

查看雇员的月薪与佣金之和

  因为sal和comm两列的类型都是数值类型,所以可以做加运算。如果sal或comm中有一个字段不是数值类型,那么会出错。

一个数与NULL进行算术运算,结果为NULL

使用IFNULL(字段名,数据)函数将某一个字段值为NULL的值转换为你指定的数据

#查询员工的所有信息以及薪水和佣金之和
SELECT *,sal+comm FROM emp;
#由于有的comm值为null,所以在于sal相加的时候,结果也为NULL。我们需要将NULL转换为0

#使用IFNULL(字段名,数据)函数将某一个字段值为NULL的值转换为你指定的数据
SELECT *,sal+IFNULL(comm,0) FROM emp;

给列名添加别名

给字段名取别名 使用AS关键字来实现,AS关键字可以省略

#给字段名取别名 使用AS关键字来实现,AS关键字可以省略
SELECT empno AS '员工编号', ename AS '员工姓名' FROM emp;
SELECT sal+IFNULL(comm,0) AS '薪水和佣金之和' FROM emp;

5.排序

        我们将数据按照要求查询出来后,可能需要按照某个字段进行升序或者降序排序,需要使用ORDER BY关键字进行排序 升序关键词ASC(升序可以省略不写),降序关键词DESC

语法:

#升序排序
SELECT * FROM 表名 ORDER BY 字段名 ASC;
SELECT * FROM 表名 ORDER BY 字段名;#升序关键词ASC可以不写,默认是升序排序

#降序排序
SELECT * FROM 表名 ORDER BY 字段名 DESC;
#查询员工的所有信息,并按照员工的sal进行升序排序
SELECT * FROM emp ORDER BY sal ASC;
SELECT * FROM emp ORDER BY sal;#升序关键词ASC可以不写,默认是升序排序

#查询员工的所有信息,并按照员工的sal进行降序排序
SELECT * FROM emp ORDER BY sal DESC;
#按照某个字段进行排序后发现,有的字段值是一样,这个时候数据按照数据表中的顺序进行排序,我们也可以再选择一个字段进行排序
#查询员工的所有信息并按照sal进行升序排序,当sal值相同时,按照员工编号empno降序排序
SELECT * FROM emp ORDER BY sal ASC, empno DESC;

#查询所有学生记录,按年龄升序排序
SELECT * FROM stu ORDER BY age ASC;
SELECT * FROM stu ORDER BY age;
#查询所有学生记录,按年龄降序排序
SELECT * FROM stu ORDER BY age DESC;

6.聚合函数  sum avg max min count

聚合函数是用来做纵向运算的函数:

1)COUNT():统计指定列不为NULL的记录行数;

2)MAX():计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;

3)MIN():计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;

4)SUM():计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;

5)AVG():计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;

#COUNT():统计指定列不为NULL的记录行数;
#统计emp表中有佣金的人数
SELECT COUNT(comm) AS '有佣金的人数' FROM emp;
#统计一共有多少员工
SELECT COUNT(*) AS '员工数' FROM emp;
#统计多少员工有领导
SELECT COUNT(mgr) AS '多少员工有领导' FROM emp;

#查询emp表中月薪大于2500的人数
SELECT COUNT(*) AS '月薪大于2500的人数' FROM emp WHERE sal>2500;
#统计月薪与佣金之和大于2500元的人数
#查询出月薪和佣金之和大于2500的员工记录
SELECT * FROM emp WHERE sal+IFNULL(comm,0)>2500;
SELECT COUNT(*) '月薪与佣金之和大于2500元的人数' FROM emp WHERE sal+IFNULL(comm,0)>2500;
#查询有佣金的人数,以及有领导的人数:
SELECT COUNT(comm) '有佣金的人数',COUNT(mgr) '有领导的人数' FROM emp;
#sum()和avg()函数
#查询所有雇员月薪和:
SELECT SUM(sal) AS'所有雇员月薪和' FROM emp;
#查询所有雇员月薪和,以及所有雇员佣金和
SELECT SUM(sal)'所有雇员月薪和',SUM(comm)'所有雇员佣金和' FROM emp;

#查询所有雇员月薪+佣金和
SELECT SUM(sal+IFNULL(comm,0)) '所有雇员月薪+佣金和' FROM emp;
#统计所有员工平均工资
SELECT AVG(sal)'所有员工平均工资' FROM emp;
#查询最高工资和最低工资:
SELECT MAX(sal) '最高工资',MIN(sal) '最低工资' FROM emp;

MySQL数据库中除了提供上述聚合函数外,还有很多的函数提供给我们使用,比如:

SELECT CONCAT('Hello','world','welcom','to','China');#合并多个字符串
SELECT LOWER('qwertyuiop');#将字符串的所有字母变成小写字母
SELECT UPPER('asdfghjkl');#将字符串转换为大写
SELECT RAND();#	返回 0 到 1 的随机数 
SELECT ADDDATE("2022-08-31",INTERVAL 30 DAY);#计算起始日期 d 加上 n 天的日期
SELECT CURDATE();#	返回当前日期
SELECT CURRENT_TIME();#返回当前时间
SELECT DATEDIFF('1949-10-01','2022-08-31');#计算日期 d1->d2 之间相隔的天数
SELECT BIN(16);#返回 x 的二进制编码

可以去浏览器搜索菜鸟教程学习相关知识 

相关文章:

  • linux共享内存
  • 小波神经网络的基本原理,小波神经网络什么意思
  • 被一位读者赶超,手摸手 Docker 部署 ELK Stack
  • Math类(Java)
  • Android项目中各文件的作用
  • Java比较器(Comparable接口)
  • ESP Insights 支持通过高级筛选进行分组分析
  • 网课答案公众号搭建的题库接口提供
  • 网课答案公众号题库在这里直接搭建使用
  • Elasticsearch: Query string与Simple query string
  • 训练神经网络用什么显卡,cpu可以训练神经网络吗
  • 中秋节到啦!程序媛请大家品尝月饼啊
  • BOM介绍以及应用以及this指向问题
  • python中列表(list)与numpy(array)的区别,行与列与维度的选择
  • js防抖和节流
  • [分享]iOS开发-关于在xcode中引用文件夹右边出现问号的解决办法
  • 【划重点】MySQL技术内幕:InnoDB存储引擎
  • 08.Android之View事件问题
  • 345-反转字符串中的元音字母
  • Android 架构优化~MVP 架构改造
  • Consul Config 使用Git做版本控制的实现
  • Hibernate最全面试题
  • Java 网络编程(2):UDP 的使用
  • JAVA之继承和多态
  • js继承的实现方法
  • v-if和v-for连用出现的问题
  • 阿里云Kubernetes容器服务上体验Knative
  • 分类模型——Logistics Regression
  • 简单实现一个textarea自适应高度
  • 开发了一款写作软件(OSX,Windows),附带Electron开发指南
  • 聊聊directory traversal attack
  • 每天10道Java面试题,跟我走,offer有!
  • 前端 CSS : 5# 纯 CSS 实现24小时超市
  • ​LeetCode解法汇总307. 区域和检索 - 数组可修改
  • #162 (Div. 2)
  • #基础#使用Jupyter进行Notebook的转换 .ipynb文件导出为.md文件
  • #微信小程序(布局、渲染层基础知识)
  • (3)(3.5) 遥测无线电区域条例
  • (42)STM32——LCD显示屏实验笔记
  • (k8s中)docker netty OOM问题记录
  • (Matalb时序预测)PSO-BP粒子群算法优化BP神经网络的多维时序回归预测
  • (附源码)python旅游推荐系统 毕业设计 250623
  • (附源码)springboot建达集团公司平台 毕业设计 141538
  • (三)Hyperledger Fabric 1.1安装部署-chaincode测试
  • (转)负载均衡,回话保持,cookie
  • (转)四层和七层负载均衡的区别
  • (状压dp)uva 10817 Headmaster's Headache
  • .bat批处理(十):从路径字符串中截取盘符、文件名、后缀名等信息
  • .gitignore
  • .locked1、locked勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .NET “底层”异步编程模式——异步编程模型(Asynchronous Programming Model,APM)...
  • .net FrameWork简介,数组,枚举
  • .NET(C#、VB)APP开发——Smobiler平台控件介绍:Bluetooth组件
  • .NET/C# 使用 ConditionalWeakTable 附加字段(CLR 版本的附加属性,也可用用来当作弱引用字典 WeakDictionary)
  • .sh