MySQL表的增删查改

文章目录

MySQL表的增删查改

  • 表的增删查改简称CRUD:Create(新增),Retrieve(查找),Update(修改),Delete(删除)。
  • CRUD的操作对象是对表当中的数据,是典型的DML(Data Manipulation Language)数据操作语言。

Create

新增数据的SQL如下:

cpp 复制代码
INSERT [INTO] table_name [(column1 [, column2] ...)] VALUES (value_list1) [, (value_list2)] ...;

说明一下:

  • SQL中大写的表示关键字,[ ]中代表的是可选项。
  • SQL中的每个value_list都表示插入的一条记录,每个value_list都由若干待插入的列值组成。
  • SQL中的column列表,用于指定每个value_list中的各个列值应该插入到表中的哪一列。

下面创建一个学生表,表当中包含自增长的主键id、学号、姓名和QQ号。如下:

创建表完毕后查看表结构,可以看到表结构如下:

单行数据+全列插入

下面使用insert语句向学生表中插入记录,每次向表中插入一条记录,并且插入记录时不指定column列表,表示按照表中默认的列顺序进行全列插入,因此插入的每条记录中的列值需要按表列顺序依次列出。如下:

多行数据+指定列插入

使用insert语句也可以一次向表中插入多条记录,插入的多条记录之间使用逗号隔开,并且插入记录时可以只指定某些列进行插入。如下:

插入否则更新

向表中插入记录时,如果待插入记录中的主键或唯一键已经存在,那么就会因为主键冲突或唯一键冲突导致插入失败。如下:

这时可以选择性的进行同步更新操作:

  • 如果表中没有冲突数据,则直接插入数据。
  • 如果表中有冲突数据,则将表中的数据进行更新。

插入否则更新的SQL如下:

cpp 复制代码
INSERT ... ON DUPLICATE UPDATE column1=value1 [, column2=value2] ...;

说明:

  • SQL中大写的表示关键字,[ ]中代表的是可选项。
  • SQL中INSERT之后语法与之前的INSERT语句相同。
  • UPDATE后面的column=value,表示当插入记录出现冲突时需要更新的列值。

比如向学生表中插入记录时,如果没有出现主键冲突则直接插入记录,如果出现了主键冲突,则将表中冲突记录的学号和姓名进行更新。如下:

执行插入否则更新的SQL后,可以通过受影响的数据行数来判断本次数据的插入情况:

  • 0 rows affected:表中有冲突数据,但冲突数据的值和指定更新的值相同。
  • 1 row affected:表中没有冲突数据,数据直接被插入。
  • 2 rows affected:表中有冲突数据,并且数据已经被更新。

替换数据

替换数据:

  • 如果表中没有冲突数据,则直接插入数据。
  • 如果表中有冲突数据,则先将表中的冲突数据删除,然后再插入数据。

要达到上述效果,只需要在插入数据时将SQL语句中的INSERT改为REPLACE即可。比如:

执行替换数据的SQL后,也可以通过受影响的数据行数来判断本次数据的插入情况:

  • 1 row affected:表中没有冲突数据,数据直接被插入。
  • 2 rows affected:表中有冲突数据,冲突数据被删除后重新插入。

Retrieve

查找数据的SQL如下:

cpp 复制代码
SELECT [DISTINCT] {* | {column1 [, column2] ...}} FROM table_name [WHERE ...] [ORDER BY ...] [LIMIT ...];

说明:

  • SQL中大写的表示关键字,[ ]中代表的是可选项。
  • { }中的 | 代表可以选择左侧的语句或右侧的语句。

为了进行演示,下面创建一个成绩表,表当中包含自增长的主键id、姓名以及该同学的语文成绩、数学成绩和英语成绩。如下:

创建表完毕后查看表结构,可以看到表结构如下:

接下来向表中插入几条测试记录,以供我们进行查找。如下:

SELECT 列

全列查询

在查询数据时直接用*代替column列表,表示进行全列查询,这时将会显示被筛选出来的记录的所有列信息。如下


注意: 通常情况下不建议使用*进行全列查询,因为被查询到的数据需要通过网络从MySQL服务器传输到本主机,查询的列越多也就意味着需要传输的数据量越大,此外,进行全列查询还可能会影响到索引的使用。

指定列查询

在查询数据时也可以只对指定的列进行查询,这时将需要查询的列在column列表列出即可。如下:

查询字段为表达式

查询数据时,column列表中除了能罗列表中存在的列名外,我们也可以将表达式罗列到column列表中。如下:

column列表中的表达式可以包含表中已有的字段,这时每当一条记录被筛选出来时,就会将记录中对应的列值提供给表达式进行计算。如下:

column列表中的表达式中也可以包含多个表中已有的字段,这时我们就可以通过表达式计算出更多有意义的数据。如下:

为查询结果指定别名

为查询结果指定别名的SQL如下:

cpp 复制代码
SELECT column [AS] alias_name [...] FROM table_name;

说明:

  • SQL中大写的表示关键字,[ ]中代表的是可选项。

比如查询成绩表中的数据时,将每条记录中的三科成绩相加,然后将计算结果对应的列指定别名为"总分"。如下:

结果去重

查询成绩表时指定查询数学成绩对应的列,可以看到数学成绩中有重复的分数。如下:

如果想要对查询结果进行去重操作,可以在SQL中的select后面带上distinct。如下:

WHERE 条件

添加where子句的区别:

  • 如果在查询数据时没有指定where子句,那么会直接将表中所有的记录作为数据源来依次执行select语句。
  • 如果在查询数据时指定了where子句,那么在查询数据时会先根据where子句筛选出符合条件的记录,然后将符合条件的记录作为数据源来依次执行select语句。

where子句中可以指明一个或多个筛选条件,各个筛选条件之间用逻辑运算符AND或OR进行关联,下面给出了where子句中常用的比较运算符和逻辑运算符。

比较运算符:

逻辑运算符:

查询英语不及格的同学及其英语成绩

在where子句中指明筛选条件为英语成绩小于60,在select的column列表中指明要查询的列为姓名和英语成绩。如下:

查询语文成绩在80到90分的同学及其语文成绩

在where子句中指明筛选条件为语文成绩大于等于80并且小于等于90,在select的column列表中指明要查询的列为姓名和语文成绩。如下:

查询数学成绩是58或59或98或99分的同学及其数学成绩

在where子句中指明筛选条件为数学成绩等于58或59或98或99,在select的column列表中指明要查询的列为姓名和数学成绩。如下:

此外,这里也可以通过IN(58, 59, 98, 99)的方式来判断数学成绩是否符合筛选要求。如下:

分别查询姓z的同学和z某同学

在where子句中通过模糊匹配来判断当前同学是否姓z(需要用到%来匹配多个字符),在select的column列表中指明要查询的列为姓名。如下:

查询语文成绩好于英语成绩的同学

在where子句中指明筛选条件为语文成绩大于英语成绩,在select的column列表中指明要查询的列为姓名、语文成绩和英语成绩。如下:

查询QQ号未知的同学

在where子句中指明筛选条件为QQ号为NULL,在select的column列表中指明要查询的列为姓名和QQ号。如下:

需要注意的是,在与NULL值作比较的时候应该使用<=>运算符,使用=运算符无法得到正确的查询结果。如下:

结果排序

结果排序的SQL如下:

cpp 复制代码
SELECT ... FROM table_name [WHERE ...] ORDER BY column [ASC | DESC] [, ...];

说明:

  • SQL中大写的表示关键字,[ ]中代表的是可选项。
  • ASC和DESC分别代表的是排升序和排降序,默认为ASC。
查询同学及其数学成绩,按数学成绩升序显示

在select的column列表中指明要查询的列为姓名和数学成绩,在order by子句中指明按照数学成绩进行升序排序。如下:

筛选分页结果

从第0条记录开始,向后筛选出n条记录:

cpp 复制代码
SELECT ... FROM table_name [WHERE ..] [ORDER BY ...] LIMIT n;

从第s条记录开始,向后筛选出n条记录:

cpp 复制代码
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT s, n;

从第s条记录开始,向后筛选出n条记录:

cpp 复制代码
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n OFFSET s;

说明:

  • SQL中大写的表示关键字,[ ]中代表的是可选项。
  • 查询SQL中各语句的执行顺序为:where、select、order by、limit。
  • limit子句在筛选记录时,记录的下标从0开始。

按id进行分页,每页2条记录,分别显示第1、2页

这里使用成绩表中的数据来演示分页查询,成绩表中的内容如下:

查询第1页记录时在查询全表数据的SQL后,加上limit子句指明从第0条记录开始,向后筛选出3条记录。如下:

查询第2页记录时在查询全表数据的SQL后,加上limit子句指明从第3条记录开始,向后筛选出3条记录。如下:

Update

修改数据的SQL如下:

cpp 复制代码
UPDATE table_name SET column1=expr1 [, column2=expr2] ... [WHERE ...] [ORDER BY ...] [LIMIT ...];

说明:

  • SQL中大写的表示关键字,[ ]中代表的是可选项。
  • SQL中的column=expr,表示将记录中列名为column的值修改为expr。
  • 在修改数据之前需要先找到待修改的记录,update语句中的where、order by和limit就是用来定位数据的。

将zhangsan同学的数学成绩修改为80分

在修改数据之前,先查看zhangsan同学当前的数学成绩。如下:

在update语句中指明要将筛选出来的记录的数学成绩改为80分,并在修改后再次查看数据确保数据成功被修改。如下:

Delete

删除数据的SQL如下:

cpp 复制代码
DELETE FROM table_name [WHERE ...] [ORDER BY ...] [LIMIT ...];

说明:

  • SQL中大写的表示关键字,[ ]中代表的是可选项。
  • 在删除数据之前需要先找到待删除的记录,delete语句中的where、order by和limit就是用来定位数据的。

删除zhangsan同学的考试成绩

在删除数据之前,先查看zhangsan同学的相关信息,然后在delete语句中指明删除孙悟空对应的记录,并在删除后再次查看数据确保数据成功被删除。如下:

删除整张表数据

在delete语句中只指明要删除数据的表名,而不通过where、order by和limit指明筛选条件,这时将会删除整张表的数据。如下:

相关推荐
he258193 分钟前
centOS 7.9 安装JDK MYSQL
java·mysql·centos
夜泉_ly2 小时前
MySQL -安装与初识
数据库·mysql
qq_529835353 小时前
对计算机中缓存的理解和使用Redis作为缓存
数据库·redis·缓存
月光水岸New6 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6756 小时前
数据库基础1
数据库
我爱松子鱼6 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo6 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser7 小时前
【SQL】多表查询案例
数据库·sql
Galeoto7 小时前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)8 小时前
MySQL主从架构
服务器·数据库·mysql