作者:爱写代码的刚子
时间:2024.3.18
前言:本篇博客将会记录表的基本查询,主要是select语句的用法。
CRUD : Create(创建), Retrieve(读取),Update(更新),Delete(删除)
语法:
INSERT [INTO] table_name [(column [, column] ...)] VALUES (value_list) [, (value_list)] ... value_list: value, [, value] ...
into是可以被省略的。
案例:
-- 创建一张学生表 CREATE TABLE students ( id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT, sn INT NOT NULL UNIQUE COMMENT '学号', name VARCHAR(20) NOT NULL, qq VARCHAR(20) );
-- 插入两条记录,value_list 数量必须和定义表的列的数量及顺序一致 -- 注意,这里在插入的时候,也可以不用指定id(当然,那时候就需要明确插入数据到那些列了),那么mysql会使用默认的值进行自增。 INSERT INTO students VALUES (100, 10000, '唐三藏', NULL); Query OK, 1 row affected (0.02 sec) INSERT INTO students VALUES (101, 10001, '孙悟空', '11111'); Query OK, 1 row affected (0.02 sec) -- 查看插入结果 SELECT * FROM students;
-- 插入两条记录,value_list 数量必须和指定列数量及顺序一致 INSERT INTO students (id, sn, name) VALUES (102, 20001, '曹孟德'), (103, 20002, '孙仲谋'); Query OK, 2 rows affected (0.02 sec) Records: 2 Duplicates: 0 Warnings: 0 -- 查看插入结果 SELECT * FROM students;
由于主键或者唯一键对应的值已经存在而导致插入失败,所以可以选择性的进行同步更新操作语法:
-- 0 row affected://表中有冲突数据,但冲突数据的值和 update 的值相等 -- 1 row affected:// 表中没有冲突数据,数据被插入 -- 2 row affected:// 表中有冲突数据,并且数据已经被更新
-- 主键 或者 唯一键 没有冲突,则直接插入; -- 主键 或者 唯一键 如果冲突,则删除后再插入 REPLACE INTO students (sn, name) VALUES (20001, '曹阿瞒'); Query OK, 2 rows affected (0.00 sec) -- 1 row affected: 表中没有冲突数据,数据被插入 -- 2 row affected: 表中有冲突数据,删除后重新插入
– 通常情况下不建议使用 * 进行全列查询
– 1. 查询的列越多,意味着需要传输的数据量越大;
– 2. 可能会影响到索引的使用。
运算符 | 说明 |
---|---|
>, >=, <, <= | 大于,大于等于,小于,小于等于 |
= | 等于,NULL不安全,例如NULL = NULL的结果是NULL |
<=> | 等于,NULL安全,例如NULL<=>NULL的结果是TRUE(1) |
!=,<> | 不等于,NULL不安全 |
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 个)任意字符;_ 表示任意一个字符 |
逻辑运算符:
运算符 | 说明 |
---|---|
AND | 多个条件必须都为TRUE(1),结果才是TRUE(1) |
OR | 任意一个条件为TRUE(1),结果为TRUE(1) |
NOT | 条件为TRUE(1),结果为FALSE(0) |
select后面跟的表示显示哪些列,不带名称则会显示全列。where后面的语句表示进行行筛选。
发现报错,所以我们要讨论一下sql语句的执行顺序:
同时不能在筛选条件(where)里面做重命名!!!因为重命名都是最后一步
语法:
– ASC 为升序(从小到大)
– DESC 为降序(从大到小)
– 默认为 ASC
注意:没有 ORDER BY 子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序
– 多字段排序,排序优先级随书写顺序
由于默认排升序:
所以我们还可以这样写:
因为要排序所以先要有合适的数据,所以这里order by后面可以跟别名
语法:
– 起始下标为 0
– 从 0 行开始,筛选 n 条结果
SELECT … FROM table_name [WHERE …] [ORDER BY …] LIMIT n;
– 从 s 行开始,筛选 n 条结果
SELECT … FROM table_name [WHERE …] [ORDER BY …] LIMIT s, n;
– 从 s 行开始,筛选 n 条结果,比第二种用法更明确,建议使用
SELECT … FROM table_name [WHERE …] [ORDER BY …] LIMIT n OFFSET s;
建议:对未知表进行查询时,最好加一条 LIMIT 1,避免因为表中数据过大,查询全表数据导致数据库卡死
按id进行分页,每页3条记录,分别显示第1、2、3页
只有数据准备好了,才要进行显示,limit的功能本质是“显示”,所以语句执行的顺序较靠后
上一篇:「PHP系列」PHP语法介绍