MySQL-DQL语句简单查询

一.什么是DQL


🥴DQL:Data Query Language数据查询语言,select用于从一个或者多个表中检索中的行(Recod)

🎯在开始进行数据库查询之前,我们需要创建几张表并且为这几张表插入相应的数据。

sql 复制代码
# 创建学生信息表
CREATE TABLE student_info (
    number INT PRIMARY KEY,
    name VARCHAR(5),
    sex ENUM('男', '女'),
    id_number CHAR(18),
    department VARCHAR(30),
    major VARCHAR(30),
    enrollment_time DATE,
    UNIQUE KEY (id_number)
);

# 创建学生成绩表
CREATE TABLE student_score (
    number INT,
    subject VARCHAR(30),
    score TINYINT,
    PRIMARY KEY (number, subject),
    CONSTRAINT FOREIGN KEY(number) REFERENCES student_info(number)
);

然后我们向我们创建的表中插入对应的数据。

sql 复制代码
# 向学生信息表中插入数据
INSERT INTO student_info ( number, NAME, sex, id_number, department, major, enrollment_time )
VALUES
	( 20180101, '杜子腾', '男', '158177199901044792', '计算机学院', '计算机科学与工程', '2018-09-01' ),
	( 20180102, '杜琦燕', '女', '151008199801178529', '计算机学院', '计算机科学与工程', '2018-09-01' ),
	( 20180103, '范统', '男', '17156319980116959X', '计算机学院', '软件工程', '2018-09-01' ),
	( 20180104, '史珍香', '女', '141992199701078600', '计算机学院', '软件工程', '2018-09-01' ),
	( 20180105, '范剑', '男', '181048199308156368', '航天学院', '飞行器设计', '2018-09-01' ),
	( 20180106, '朱逸群', '男', '197995199501078445', '航天学院', '电子信息', '2018-09-01' );

# 向学生成绩表中插入数据
INSERT INTO student_score ( number, SUBJECT, score )
VALUES
	( 20180101, '母猪的产后护理', 78 ),
	( 20180101, '论萨达姆的战争准备', 88 ),
	( 20180102, '母猪的产后护理', 100 ),
	( 20180102, '论萨达姆的战争准备', 98 ),
	( 20180103, '母猪的产后护理', 59 ),
	( 20180103, '论萨达姆的战争准备', 61 ),
	( 20180104, '母猪的产后护理', 55 ),
	( 20180104, '论萨达姆的战争准备', 46 );

然后我们可以在Navicat上面查询自己创建的表首先是学生信息表。

然后我们再查看学生成绩表。

二.简单的查询


😊查询表中的某一列的数据。

sql 复制代码
SELECT `name` from `student_info`;

我们在查询某一列的数据的时候还可以指定列的别名,通过以下的方式。

sql 复制代码
SELECT `name` AS 'othername' from `student_info`;

我们会发现查询的结果列的别名发生了变化,从原来的name变成了我们指定的othername,别名也有简写的方式来指定。

sql 复制代码
SELECT `name` '名字' FROM `student_info`;

🧙一次性查询多个表中的字段,多个字段之间通过,分割。

sql 复制代码
SELECT `name`,`sex`,`number` FROM `student_info`;

🤡一次性查询表中的所有数据字段;

sql 复制代码
SELECT * FROM `student_info`;

😁对查询结果去重,我们查询下student_info然后查看下结果。

sql 复制代码
SELECT `department` FROM `student_info`;

我们会看到有很多重复的内容,我们需要对它们进行去重,去重需要使用DISTINCT放在列名前进行去重

sql 复制代码
SELECT DISTINCT `department` FROM `student_info`;

然后我们就会发现重复的内容被我们去掉了。


👽对多行的重复的情况进行去重

sql 复制代码
SELECT DISTINCT `department`,`major` FROM `student_info`;

🦊对查询的条数进行限制,因为有的时候数据很多会直接把屏幕撑爆,所以我们很多情况下需要限制条数

sql 复制代码
LIMIT 开始行, 限制条数;
sql 复制代码
SELECT `number`,`name`,`department` FROM `student_info` LIMIT 0,4;

当然我们也可以使用MySQL指定的默认行,仅仅对条数进行限制。

sql 复制代码
SELECT `number`,`name`,`department` FROM `student_info` LIMIT 4;

😶‍🌫️对查询结果进行排序,排序的语法如下:其中ASC表示升序,DESC表示降序。

sql 复制代码
ORDER BY 列名 ASC|DESC

那么我们对刚才新建的成绩表进行按照score进行降序排序。

sql 复制代码
SELECT * FROM `student_score` ORDER BY `score` DESC;

🎯按照多列的值进行排序,语法如下,不同的字段使用,隔开,不写排序方式默认升序排序。

sql 复制代码
ORDER BY 列1 ASC|DESC, 列2 ASC|DESC ...
sql 复制代码
SELECT * FROM `student_score` ORDER BY `subject`,`score` DESC; 

三.案例练习


😊找出成绩表中成绩最低的那条记录。

sql 复制代码
SELECT * FROM `student_score` ORDER BY `score` ASC LIMIT 1;

🧙其实这就涉及到了limitorder by的混合使用,limit需要在order by后面使用,然后让整个成绩表进行升序,然后取第一条就是成绩最低的那条数据。

相关推荐
zqx_714 分钟前
随记 前端框架React的初步认识
前端·react.js·前端框架
惜.己31 分钟前
javaScript基础(8个案例+代码+效果图)
开发语言·前端·javascript·vscode·css3·html5
什么鬼昵称1 小时前
Pikachu-csrf-CSRF(get)
前端·csrf
长天一色1 小时前
【ECMAScript 从入门到进阶教程】第三部分:高级主题(高级函数与范式,元编程,正则表达式,性能优化)
服务器·开发语言·前端·javascript·性能优化·ecmascript
NiNg_1_2341 小时前
npm、yarn、pnpm之间的区别
前端·npm·node.js
秋殇与星河2 小时前
CSS总结
前端·css
BigYe程普2 小时前
我开发了一个出海全栈SaaS工具,还写了一套全栈开发教程
开发语言·前端·chrome·chatgpt·reactjs·个人开发
余生H2 小时前
前端的全栈混合之路Meteor篇:关于前后端分离及与各框架的对比
前端·javascript·node.js·全栈
程序员-珍2 小时前
使用openapi生成前端请求文件报错 ‘Token “Integer“ does not exist.‘
java·前端·spring boot·后端·restful·个人开发
axihaihai2 小时前
网站开发的发展(后端路由/前后端分离/前端路由)
前端