MySQL 使用DQL命令查询数据的实现方法
作者:CFF_伊人 发布时间:2024-01-16 18:53:13
本篇文章博主将带大家一起学习MySQL中常用的数据查询语言。
DQL(Data Query Language 数据查询语言)
SELECT 语法
SELECT [ALL | DISTINCT]
{ * | table.* | [table.field1 [as alias1][,table.field2] [as alias2][,...]]}
FROM table_name [as table_alias]
[left | out | inner join table_name2] #联合查询
[WHERE ...] #指定结果需要满足的条件
[GROUP BY ...] #指定结果按照哪几个字段来分组
[HAVING ...] #过滤分组的记录必须满足的次要条件
[ODER BY ...] #指定查询记录按一个或者多个条件排序
[LIMIT [偏移量,返回结果记录数]; #指定查询的记录从哪条至哪条
基本查询语句&AS
以下例子用student表中的数据。
查询表中所有数据列结果,采用 “*” 符号,效率低
select * from student;
可指定查询列,效率高
select StudentName,Phone from student;
AS 子句的作用和用法
注意:AS 可省略不写
(1)可给数据列取一个新别名
select StudentName as '学生姓名' from student;
(2)给表取别名
select stu.address from student as stu;
(3)可把计算或总结的结果用另一个新名称来代替
SELECT Phone +1 AS Tel FROM student;
DISTINCT 关键字
作用:去掉SELECT查询出来的重复值(当所有返回值都相同时,只返回一条记录)
语法:
SELECT DISTINCT 字段名1,字段名2,... from 表名
注意:ALL 关键字是默认的,返回所有记录,与之相反
当过滤多列重复值时,只有当选择过滤的列都存在重复值才进行过滤
SELECT DISTINCT StudentNo,address from student;
过滤单列:查询学生表中的地址
SELECT DISTINCT address from student;
SQL语句中的表达式
SELECT VERSION(),100*3 as 乘积; #返回Mysql 版本和计算结果
SELECT NOW() '当前时间'; #返回当前时间
避免SQL返回结果中包含“.” ,“*”,和括号等干扰开发语言程序
SELECT VERSION() as MySQL_V,12.3*100 as expression;
#返回结果不会与后台开发程序发生混淆
拼接 CONCAT
SELECT CONCAT(studentName,'@.com') as Email from student;
数值类型相加
select StudentNo+100 from student;
比较运算符&通配符
where条件语句:用于检索数据表中符合条件的记录
搜索条件可以由一个或多个逻辑表达式组成,结果一般为真或假
搜索条件的组成:逻辑操作符、比较操作符
#where 条件语句
select * from student where address='四川';
#查询学生表中电话号码不为空的学员姓名
select StudentName from student where Phone is not null;
#查询学生表中电话号码为空的学员姓名
select StudentName from student where Phone is null;
#查询刚删掉的数据——空值
select StudentName from student where Phone = '';
# BETWEEN AND 适用于时间范围
逻辑操作符
比较操作符
使用 LIKE 关键字进行模糊查询
与“%”一起使用,表示匹配0个或任意个字符
与“_”一起使用 表示匹配单个字符
#查询学生表中姓张*的学生姓名
SELECT StudentName from student where studentname like '张_';
SELECT StudentName from student where studentname like '%丽%';
# IN
SELECT * from student where Address in ('四川','上海');
注意:
数值数据类型的记录之间才能进行算数运算
相同的数据类型的数据之间才能进行比较
NULL
null 代表“无值”
区别于零值0和空字符串“ ”
只能出现在定义允许为NULL的字段
须使用 IS NULL 或 IS NOT NULL 比较操作符去比较
内连接&自查询
如果需要多张数据表的数据进行查询,则可以通过连接运算符实现多个查询。
分类包括:
内连接(inner jion):
等值和非等值的连接查询
自身连接查询
外连接(out jion)
左连接(LEFT JION)
右连接(RIGHT JION)
ORDER BY 排序查询
对select 语句查询得到的结果,按某些字段进行排序
与DESC(降序)或ASC(升序)搭配使用,默认为ASC
以subject表和grade表数据为例:
SELECT * from subject ORDER BY classhour; #升序
SELECT * from subject ORDER BY classhour desc; #降序
多字段排序:先按照第一个字段排序,再按照第二个字段排序。如果第一个字段数据相同,再按照第二个字段排序。
SELECT * from subject ORDER BY classHour,GradeID;
LIMIT分页
LIMIT [m,] n 或 LIMIT n OFFSET m
限制SELECT返回结果的行数
m为第一个返回记录行的偏移量
n返回记录行的数目
注意:
m不指定,则偏移量为0,从第一条开始返回前n条记录
LIMIT 常用于分页显示
如果超出表中数据,则显示全部
例如:
SELECT * FROM grade LIMIT 3; #返回前3条记录
SELECT * FROM grade LIMIT 1,3; #返回2~4条记录
总记录数:total
SELECT COUNT(subjectNO) '总数据' from subject;
总页数:int totalPage = total % pagesize ==0 ? total / pagesize : total / pagesize + 1
子查询
在查询语句WHERE 条件子句中,又嵌套了另外一个查询语句
注意:子查询返回的结果一般是集合,建议使用IN关键字
SELECT subjectName from subject
where gradeID IN
(SELECT GradeID from grade);
聚合函数
常用的统计函数:COUNT()、SUM()、AVG()、MAX()、MIN()
SELECT COUNT(StudentNo) '总数据' FROM student;
SELECT sum(classHour) '总学时'from subject;
SELECT AVG(classHour) '平均学时' FROM subject;
SELECT MAX(classHour) '最长学时' FROM subject;
SELECT MIN(classHour) '最短学时' FROM subject;
分组 GROUP BY
使用 GROUP BY 关键字对查询结果分组
对所有的数据进行分组统计
分组的字段可以有多个,并依次分组
与 HAVING 结合使用,进行分组后的数据筛选
以 student 表为例
(1)对student 表按照地址分组统计 group by
SELECT Address,COUNT(Address) FROM student GROUP BY Address;
HAVING 过滤分组的记录必须满足的次要条件
(2)对 student 表 按照地址分组,满足地址=1的 HAVING
SELECT GROUP_CONCAT(StudentName),COUNT(Address) FROM student GROUP BY Address HAVING COUNT(Address)=1;
合并 UNION 、UNION
ALLUNION #合并完全相同数据
UNION ALL #合并所有数据
注意:合并两张表时,列数必须一样才能合并。
两表列数不同时,会报以下错误:
[SQL]SELECT * FROM grade UNION SELECT * FROM student;
[Err] 1222 - The used SELECT statements have a different number of columns
(1)合并 subject 表和 student表
SELECT * FROM subject UNION SELECT * FROM student;
SELECT * FROM subject UNION ALL SELECT * FROM student;
子查询 EXISTS ——>true false
EXISTS / NOT EXISTS 子查询条件成立则显示父查询的结果,否则不显示结果
(1)子查询条件为真 (grade 表中 gradeid 1~5,存在 1)
SELECT subjectName,GradeID FROM subject
WHERE EXISTS
(SELECT * FROM grade WHERE GradeID=1);
或
SELECT subjectName,GradeID FROM subject
WHERE NOT EXISTS
(SELECT * FROM grade WHERE GradeID=999);
(2)子查询条件为假 (grade 表中 gradeid 1~5,不存在 999)
SELECT subjectName,GradeID FROM subject
WHERE EXISTS
(SELECT * FROM grade WHERE GradeID=999);
或
SELECT subjectName,GradeID FROM subject
WHERE NOT EXISTS
(SELECT * FROM grade WHERE GradeID=1);
子查询(any & all)
ANY :判断条件中,若子查询中任意一个值满足条件,则执行父查询
ALL :判断条件中,若子查询中所有值满足条件,则执行父查询
(1)满足条件:存在 subject.gradeid >= grade.gradeid ,执行父查询
SELECT subjectname,gradeid FROM subject
WHERE GradeID >=ANY
(SELECT GradeID FROM grade);
(2)不满足条件:所有subject.gradeid >= grade.gradeid ,不执行父查询
SELECT subjectname,gradeid FROM subject
WHERE GradeID >=ALL
(SELECT GradeID FROM grade);
来源:https://blog.csdn.net/weixin_43817064/article/details/97936194
猜你喜欢
- DELETE 语句DELETE 语句用于删除记录,语法如下:(与 “UPDATE” 语法较为相似)D
- ShuffleNet是由旷世发表的一个计算效率极高的CNN架构,它是专门为计算能力非常有限的移动设备(例如,10-150 MFLOPs)而设
- 本文实例分析了Python字符串和文件操作常用函数。分享给大家供大家参考。具体如下:# -*- coding: UTF-8 -*-'
- 前言本篇文章,阐述一下Flask中数据库的迁移为什么要说数据库迁移呢?比如我们以前有一个数据库,里面的信息有 id, name现在我想再加一
- 神经网络模型一般用来做分类,回归预测模型不常见,本文基于一个用来分类的BP神经网络,对它进行修改,实现了一个回归模型,用来做室内定位。模型主
- keys()方法返回在字典中的所有可用的键的列表。语法以下是keys()方法的语法:dict.keys()参数 &nb
- 选择排序算法步骤:找到数组中最小的那个元素中,将它和数组的第一个元素交换位置,在剩下的元素中找到最小的元素,将它和数组的第二个元素交换位置,
- 废话不多说,直接开始拉~~~我们总共有 6 只海龟,颜色不同,它们以随机长度移动。首先,我们应该通过输入乌龟的颜色来押注乌龟。第一个越线的乌
- .tkintertkinter是Python下面向tk的图形界面接口库,可以方便地进行图形界面设计和交互操作编程。tkinter的优点是简单
- 本文实例讲述了Python3对称加密算法AES、DES3。分享给大家供大家参考,具体如下:python3.6此库安装方式,需要pip3 in
- 例一:使用httplib访问某个url然后获取返回的内容:import httplibconn=httplib.HTTPConne
- 使用Keras作前端写网络时,由于训练图像尺寸较大,需要做类似 tf.random_crop 图像裁剪操作。为此研究了一番Keras下已封装
- 本文实例讲述了python实现自动登录人人网并访问最近来访者的方法,分享给大家供大家参考。具体方法如下:##-*- coding : gbk
- itertools.product:类似于求多个可迭代对象的笛卡尔积。使用的形式是:itertools.product(*iterables
- 版本信息:python:3.6mysql:5.7pyMysql:0.7.11################################
- 如果你只使用一个更新日志,你只须清空日志文件,然后移走旧的更新日志文件到一个备份中,然后启用新的更新日志。用下列方法可以强制服务器启用新的更
- 本文实例讲述了Python单元测试与测试用例。分享给大家供大家参考,具体如下:单元测试与测试用例简介测试用例是一组单元测试,这些单元测试一起
- 本文实例讲述了python中map、any、all函数用法。分享给大家供大家参考。具体分析如下:最近想学python,就一直比较关注pyth
- 疫情肆虐,憋在家实在无聊,索性写点东西,于是就有了这个极极极极极简的音乐播放器。这个极极极简的音乐播放器类似于“阅后即焚”的软件,播放器可以
- 内容摘要:Microsoft建立了一种既灵活又强大的安全管理机制,它能够对用户访问SQL Server服务器系统和数据库的安全进行