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

【MySQL】基本查询(上):创建、读取

1.Create(创建)

语法:

INSERT [INTO] table_name
[(column [, column] ...)]
VALUES (value_list) [, (value_list)] ...value_list: value, [, value] ...

接下来我们用这个下表作为例子:

-- 创建一张学生表
CREATE TABLE students (
id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
sn INT NOT NULL UNIQUE COMMENT '学号',
name VARCHAR(20) NOT NULL,
qq VARCHAR(20)
);

可以看到,我们成功创建了一个表

1.1 单行数据 全列插入

-- 插入两条记录,value_list的数量和顺序必须与定义表的列的一致
insert into students values (100, 1000, '张三', NULL);
insert into students values (101, 1001, '李四', '1234');
-- 插看插入结果
select * from students;

1.2 多行数据 指定列插入

-- 插入两条记录,value_list 数量必须和指定列数量及顺序一致
insert into students (id, number, name) values
(102, 1002, '王五'),
(103, 1003, '赵六');-- 查看插入结果
SELECT * FROM students;

1.3 插入/更新

由于我们在定义这个学生表时,将id设定为主键,将number设定为唯一键,则它们的值都是唯一的,如果我们的插入语句中出现重复的id或number,mysql就会报错,插入失败。

主键冲突:

唯一键冲突:

其实我们可以选择性地进行同步更新操作:

INSERT ... ON DUPLICATE KEY UPDATE
column = value [, column = value] ...-- ON DUPLICATE KEY 当发生重复key的时候

1.4 替换

-- 主键 或者 唯一键 没有冲突,则直接插入;
-- 主键 或者 唯一键 如果冲突,则删除后再插入
REPLACE INTO students (number, name) VALUES (1001, '李小帅');

大家可以发现:replace和on duplicate key update的区别在于:如果要插入的行已存在,replace会删除原来行,然后插入新行,适用于希望完全替换已存在行的情况;on duplicate key update则不会删除旧行,而是更新已存在行的指定列,适用于希望保留现有数据并更新部分字段的情况。

2.Retrieve(读取)

语法:

SELECT
[DISTINCT] {* | {column [, column] ...}
[FROM table_name]
[WHERE ...]
[ORDER BY column [ASC | DESC], ...]
LIMIT ...

接下来我们还是用一张表来做例子:

-- 创建表结构
create table exam_result(
id int unsigned primary key auto_increment,
name varchar(20) not null,
Chinese float default 0.0 comment '语文成绩',
Math float default 0.0 comment '数学成绩',
English float default 0.0 comment '英语成绩'
);-- 插入测试数据
INSERT INTO exam_result (name, chinese, math, english) VALUES
('唐三藏', 67, 98, 56),
('孙悟空', 87, 78, 77),
('猪悟能', 88, 98, 90),
('曹孟德', 82, 84, 67),
('刘玄德', 55, 85, 45),
('孙权', 70, 73, 78),
('宋公明', 75, 65, 30);

2.1 基础查询

全列查询

-- 通常情况下不建议进行全列查询
-- 1. 查询的列越多,意味着需要传输的数据量越大;
-- 2. 可能会影响到索引的使用。select * from exam_result;

指定列查询

-- 指定列的查询不需要按表定义的顺序来
select name, Chinese from exam_result;

查询字段为表达式

-- 表达式不包含字段
select name, 10 from exam_result;、

-- 表达式包含一个字段
select id, name, English + 10 from exam_result;

-- 表达式包含多个字段
select name, Chinese + Math + English from Exam_result;

-- 为查询结果指定别名
select name as '姓名', Chinese + Math + English as '总分' from exam_result;

2.4 distinct去重

-- 98 分重复了
select Math from exam_result;-- 对结果进行去重
select distinct Math from exam_result;

不去重的结果:

去重的结果:

2.2 where 条件

运算符
说明
>, >=, <, <=
大于,大于等于,小于,小于等于
=
等于, NULL 不安全,例如 NULL = NULL 的结果是 NULL
<=>
等于, NULL 安全,例如 NULL <=> NULL 的结果是 TRUE(1)
!=, <>
不等于
BETWEEN a0 AND a1
范围匹配, [a0, a1] ,如果 a0 <= value <= a1 ,返回 TRUE(1)
IN (option, ...)
如果是 option 中的任意一个,返回 TRUE(1)
IS NULL
NULL
IS NOT NULL
不是 NULL
LIKE
模糊匹配。 % 表示任意多个(包括 0 个)任意字符; _ 表示任意一个字符

举几个例子:

英语不及格的同学及英语成绩 ( < 60 ):
语文成绩在 [80, 90] 分的同学及语文成绩:
数学成绩是 58 或者 59 或者 98 或者 99 分的同学及数学成绩:

姓孙的同学 及 孙某同学:
语文成绩好于英语成绩的同学:
总分在 200 分以下的同学:
语文成绩 > 80 并且不姓孙的同学:
孙某同学,否则要求总成绩 > 200 并且 语文成绩 < 数学成绩 并且 英语成绩 > 80:

2.3 order by 对结果排序

语法:

-- ASC 为升序(从小到大)
-- DESC 为降序(从大到小)
-- 默认为 ASC
SELECT ... FROM table_name [WHERE ...]
ORDER BY column [ASC|DESC], [...];

依然是举几个例子:

同学及数学成绩,按数学成绩升序显示:

查询同学各门成绩,依次按 数学降序,英语升序,语文升序的方式显示:

查询同学及总分,由高到低:

查询姓孙的同学或者姓曹的同学数学成绩,结果按数学成绩由高到低显示:

2.4 limit 筛选分页结果

-- 起始下标为 0
-- 从 s 开始,筛选 n 条结果
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT s, n
-- 从 0 开始,筛选 n 条结果
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n;
;
-- 从 s 开始,筛选 n 条结果,比第二种用法更明确,建议使用
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n OFFSET s;

 建议对未知表进行查询时最好加一条limit1,这样能避免由于表数据量过大,查询全表数据导致数据库卡死。

使用例子:

-- 第 1 页
SELECT id, name, math, english, chinese FROM exam_result
ORDER BY id LIMIT 3 OFFSET 0;

-- 第 2 页
SELECT id, name, math, english, chinese FROM exam_result
ORDER BY id LIMIT 3 OFFSET 3;

-- 第 3 页,如果结果不足 3 个,不会有影响
SELECT id, name, math, english, chinese FROM exam_result
ORDER BY id LIMIT 3 OFFSET 6;


剩下的删和改我们留到下篇文章再继续学习,希望大家看完文章之后也可以动手写一写sql语句,一开始不熟练也没关系,后面会越来越熟悉的~

http://www.lryc.cn/news/460825.html

相关文章:

  • 在线刷题系统测试报告
  • 即时通讯增加Redis渠道
  • C++list
  • 设计模式 - 结构型
  • STM32编码器接口
  • 2024客户世界年度大会开幕,码号卫士赋能数字运营服务新升级
  • AcWing 802. 区间和(离散化算法,python)
  • 【网页设计】CSS 盒子模型
  • 如何通过构建对应的api服务器使Vue连接到数据库
  • 新手给视频加字幕的方法有哪些?4种加字幕方法推荐!
  • Oracle实际需要用到但常常被忽略的函数
  • 代码随想录算法训练营Day23
  • vue使用table实现动态数据报表(行合并)
  • YARN调度原理详解
  • Go-知识泛型
  • Qt 如何 发送与解析不定长报文以及数组不定长报文
  • Rust默认使用UTF-8编码来解析源代码文件。如果在代码中包含无法用UTF-8编码表示的字符,编译器会报错!
  • 【jeston】torch相关环境安装
  • [CR]厚云填补_大型卫星影像去云数据集
  • Langchain CharacterTextSplitter无法分割文档问题
  • ros service不走是为什么
  • 量子计算机的原理与物理实现
  • SQL Server 常用关键词语法汇总
  • 软件测试工程师面试整理 —— 操作系统与网络基础!
  • 网络安全防御策略:通过限制IP访问提升服务器安全性
  • Multiprocessing出错没有提示was skipped without notice in python
  • 调整应用窗口透明度
  • 启智畅想集装箱号码智能识别原理,OCR识别应用
  • React基础知识
  • Java基础:面向对象编程3