MySQL 插入、更新与删除表中数据


↠前言↞

这篇文章主要介绍了✎:mysql 数据插入、更新及删除,文章围绕mysql 数据插入和更新及删除的相关资料展开内容。如发现错误,及时告知,及时纠正,感谢支持。

↻ . 准备工作

先使用一个数据库,并添加一张数据表,具体操作如下:

1)使用数据库

mysql> USE itcsat;
Database changed

2)创建数据表

mysql> CREATE TABLE student
    -> (
    ->    id INT(5),
    ->    name CHAR(20)NOT NULL,
    ->    sex CHAR(5),
    ->    grade FLOAT(5)
    -> );
Query OK, 0 rows affected

3)查看数据表是否存在

mysql> SHOW TABLES;
+------------------+
| Tables_in_itcsat |
+------------------+
| student          |
+------------------+
1 row in set

4)查看数据表信息 (两种方法)

mysql> SHOW CREATE TABLE student;
+---------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table   | Create Table                                                                                                                                                               |
+---------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| student | CREATE TABLE `student` (
  `id` int(5) DEFAULT NULL,
  `name` char(20) NOT NULL,
  `sex` char(5) DEFAULT NULL,
  `grade` float DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=gbk |
+---------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set
mysql> DESC student;//查看的是表格的具体信息
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| id    | int(5)   | YES  |     | NULL    |       |
| name  | char(20) | NO   |     | NULL    |       |
| sex   | char(5)  | YES  |     | NULL    |       |
| grade | float    | YES  |     | NULL    |       |
+-------+----------+------+-----+---------+-------+
4 rows in set

㊀ . 插入数据

在这里插入图片描述

第一种添加方法

直接一一对应添加数据。
eg1:

INSERT INTO student(id,name,sex,grade)VALUES(1,"张三","男",89);
Query OK, 1 row affected

查看数据是否添加成功:

SELECT *FROM student;
mysql> SELECT *FROM student;
+----+------+-----+-------+
| id | name | sex | grade |
+----+------+-----+-------+
|  1 | 张三 | 男  |    89 |
+----+------+-----+-------+
1 row in set

注意:可以改变字段名的顺序,但值也要相应改变,字段名必须和值相对应。

eg2:

mysql> INSERT INTO student(name,id,grade,sex)VALUES("李四",2,80,"男");
Query OK, 1 row affected
mysql> SELECT *FROM student;
+----+------+-----+-------+
| id | name | sex | grade |
+----+------+-----+-------+
|  1 | 张三 | 男  |    89 |
|  2 | 李四 | 男  |    80 |
+----+------+-----+-------+
2 rows in set

第二种添加方法

可以没有字段名,这样的话就和你建立的数据表的字段名一致。

eg3:

mysql> INSERT INTO student VALUES(3,"王二","男",98);
Query OK, 1 row affected
mysql> SELECT *FROM student;
+----+------+-----+-------+
| id | name | sex | grade |
+----+------+-----+-------+
|  1 | 张三 | 男  |    89 |
|  2 | 李四 | 男  |    80 |
|  3 | 王二 | 男  |    98 |
+----+------+-----+-------+
3 rows in set

第三种添加方法

字段可以不全部添加完,只添加其中几个。

eg4:

mysql> INSERT INTO student(id,name,grade)VALUES(4,"麻子",89);
Query OK, 1 row affected
mysql> SELECT * FROM student;
+----+------+------+-------+
| id | name | sex  | grade |
+----+------+------+-------+
|  1 | 张三 | 男   |    89 |
|  2 | 李四 | 男   |    80 |
|  3 | 王二 | 男   |    98 |
|  4 | 麻子 | NULL |    89 |
+----+------+------+-------+
4 rows in set

eg5:

mysql> INSERT INTO student(id,sex,grade)VALUES(5,"男",78);
Query OK, 1 row affected
mysql> SELECT *FROM student;
+----+------+------+-------+
| id | name | sex  | grade |
+----+------+------+-------+
|  1 | 张三 | 男   |    89 |
|  2 | 李四 | 男   |    80 |
|  3 | 王二 | 男   |    98 |
|  4 | 麻子 | NULL |    89 |
|  5 |      | 男   |    78 |
+----+------+------+-------+
5 rows in set

在这里插入图片描述

第四种添加方法

连续多行输入。

INSERT INTO student(id,name,sex,grade)VALUES(6,"巴西","女",67),(7,"万茜","女",88);
Query OK, 3 rows affected
Records: 3  Duplicates: 0  Warnings: 0

eg6:

mysql> SELECT *FROM student;
+----+------+------+-------+
| id | name | sex  | grade |
+----+------+------+-------+
|  1 | 张三 | 男   |    89 |
|  2 | 李四 | 男   |    80 |
|  3 | 王二 | 男   |    98 |
|  4 | 麻子 | NULL |    89 |
|  5 |      | 男   |    78 |
|  6 | 巴西 | 女   |    67 |
|  7 | 万茜 | 女   |    88 |
+----+------+------+-------+
7 rows in set

㊁ . 更新数据

MySQL中使用UPDATE语句来更新表中的记录,其中的基本语法格式如下:
在这里插入图片描述

➀ . 更新一条记录中的一个字段

eg1:

mysql> UPDATE student SET name="图雪芳" WHERE id=1;
Query OK, 1 row affected
Rows matched: 1  Changed: 1  Warnings: 0
mysql> SELECT *FROM student;
+----+--------+------+-------+
| id | name   | sex  | grade |
+----+--------+------+-------+
|  1 | 图雪芳 | 男   |    89 |
|  2 | 李四   | 男   |    80 |
|  3 | 王二   | 男   |    98 |
|  4 | 麻子   | NULL |    89 |
|  5 |        | 男   |    78 |
|  6 | 巴西   | 女   |    67 |
|  7 | 万茜   | 女   |    88 |
+----+--------+------+-------+
7 rows in set

➁ . 更新几条记录中的相同字段

eg2:

mysql> UPDATE student SET sex="女" WHERE id<4;
Query OK, 3 rows affected
Rows matched: 3  Changed: 3  Warnings: 0
mysql> SELECT *FROM student;
+----+--------+------+-------+
| id | name   | sex  | grade |
+----+--------+------+-------+
|  1 | 图雪芳 | 女   |    89 |
|  2 | 李四   | 女   |    80 |
|  3 | 王二   | 女   |    98 |
|  4 | 麻子   | NULL |    89 |
|  5 |        | 男   |    78 |
|  6 | 巴西   | 女   |    67 |
|  7 | 万茜   | 女   |    88 |
+----+--------+------+-------+
7 rows in set

➂ . 更新整个数据表数据的某个信息

eg3:

mysql> UPDATE student SET sex="女";
Query OK, 2 rows affected
Rows matched: 8  Changed: 2  Warnings: 0
mysql> SELECT *FROM student;
+----+--------+-----+-------+
| id | name   | sex | grade |
+----+--------+-----+-------+
|  1 | 图雪芳 | 女  |    89 |
|  2 | 李四   | 女  |    80 |
|  3 | 王二   | 女  |    98 |
|  4 | 麻子   | 女  |    89 |
|  5 |        | 女  |    78 |
|  6 | 巴西   | 女  |    67 |
|  7 | 万茜   | 女  |    88 |
+----+--------+-----+-------+
7 rows in set

㊂ . 删除数据

MySQL中使用DELETE语句来删除表中的记录,其中语法格式如下:
在这里插入图片描述

Ⅰ. 删除其中一条数据

eg1:

mysql> DELETE FROM student WHERE id=5;
Query OK, 1 row affected
mysql> SELECT *FROM student;
+----+--------+-----+-------+
| id | name   | sex | grade |
+----+--------+-----+-------+
|  1 | 图雪芳 | 女  |    89 |
|  2 | 李四   | 女  |    80 |
|  3 | 王二   | 女  |    98 |
|  4 | 麻子   | 女  |    89 |
|  6 | 巴西   | 女  |    67 |
|  7 | 万茜   | 女  |    88 |
+----+--------+-----+-------+
6 rows in set

Ⅱ . 删除其中的几条数据

eg3:

mysql> DELETE FROM student WHERE id>4;
Query OK, 3 rows affected
mysql> SELECT *FROM student;
+----+--------+-----+-------+
| id | name   | sex | grade |
+----+--------+-----+-------+
|  1 | 图雪芳 | 女  |    89 |
|  2 | 李四   | 女  |    80 |
|  3 | 王二   | 女  |    98 |
|  4 | 麻子   | 女  |    89 |
+----+--------+-----+-------+
4 rows in set

Ⅲ . 表中的记录全部删除

eg4:

mysql> DELETE FROM student;
Query OK, 4 rows affected
mysql> SELECT *FROM student;
Empty set

从查询结果中科院看到记录为空,说明表中所有的记录成功删除。

㊃ . 知识拓展:使用关键字TRUNCATE删除表中数据

准备工作

删除原来的student数据表,新建一个数据表,添加数据,查看一下,准备工作就准备完毕了。

mysql> DROP TABLE student;
Query OK, 0 rows affected
mysql> SHOW TABLES;
Empty set
mysql> CREATE TABLE student
    -> (
    ->   id INT(10),
    ->   name CHAR(20)
    -> );
Query OK, 0 rows affected
mysql> DESC student;
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| id    | int(10)  | YES  |     | NULL    |       |
| name  | char(20) | YES  |     | NULL    |       |
+-------+----------+------+-----+---------+-------+
2 rows in set
mysql> INSERT INTO student(name)VALUES("黄珊"),("黄蓉"),("郭襄"),("杨过"),("张无忌");
Query OK, 5 rows affected
Records: 5  Duplicates: 0  Warnings: 0
mysql> SELECT *FROM student;
+------+--------+
| id   | name   |
+------+--------+
| NULL | 黄珊   |
| NULL | 黄蓉   |
| NULL | 郭襄   |
| NULL | 杨过   |
| NULL | 张无忌 |
+------+--------+
5 rows in set

使用TRUNCATE执行结果如下:

mysql> TRUNCATE TABLE student;
Query OK, 0 rows affected
mysql> SELECT *FROM student;
Empty set

从查询结果中科院看到记录为空,说明表中所有的记录成功删除。

TRUNCATE与DELETE的区别

1,DELETE语句是DML语句,TRUNCATE语句通常被认为是DDL语句。
2,DELETE语句后面可以跟WHERE字句,通过指定WHERE子句中的条件表达式是删除满足条件的部分记录,而TRUNCATE语句只能用于删除表中所有记录。
3,使用TRUNCATE语句删除表中的数据后,再次向表中添加记录时,自动增加字段的默认初始值重新由1开始,而使用DELETE删除表中所有记录后,再次向表中添加记录时,自动增加字段的值为删除时该字段的最大值加1。
4,使用DELETE语句是,没删除一条记录都会在日志中记录,而使用TRUNCATE语句时,不会在日志中记录删除的内容,因此TRUNCATE语句的执行效率比DELETE语句高。

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梁辰兴

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值