SQL学习之update语句

参考源

SQL update 语句

SQL update 语句用于更新表中已存在的记录

单张表:

UPDATE [LOW_PRIORITY] [IGNORE] table_reference
    SET assignment_list
    [WHERE where_condition]
    [ORDER BY ...]
    [LIMIT row_count]

多张表:

UPDATE [LOW_PRIORITY] [IGNORE] table_references
    SET assignment_list
    [WHERE where_condition]

注:

  1. SQL update 语句中的 where子句规定哪条记录或者哪些记录需要更新

  2. 如果省略了 where 子句,所有的记录都将被更新

示例数据

CREATE DATABASE IF NOT EXISTS hardy_db DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci;

USE hardy_db;

DROP TABLE IF EXISTS lesson;

CREATE TABLE lesson (
	id INT ( 11 ) NOT NULL PRIMARY KEY AUTO_INCREMENT,
	name VARCHAR ( 32 ) DEFAULT '',
	views INT ( 11 ) NOT NULL DEFAULT 0,
	created_at TIMESTAMP 
);

INSERT INTO lesson ( id, name, views, created_at )
VALUES
	( 1, 'Python 基础教程', 981, '2019-03-18 13:52:03' ),
	( 2, 'JavaScript 基础教程', 73, '2019-03-18 16:03:32' ),
	( 3, 'Ruby 基础教程', 199, '2019-04-01 06:16:14' ),
	( 4, 'SQL 基础教程', 533, '2019-05-02 08:13:42' ),
	( 5, 'Linux 基础教程', 1000, '2019-06-02 08:13:42' );

SQL update

将 <Python 基础教程> 改成 <Python3 基础教程>

那么可以使用下面的 SQL 语句

update lesson set name='Python3 基础教程' where name = 'Python 基础教程';

运行 SQL 语句,输出结果如下

mysql> update lesson set name='Python3 基础教程' where name = 'Python 基础教程';

Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0

使用 SQL 中的 select 语句 查看 lesson 表,显示如下

mysql> select * from lesson;
+----+--------------------+-------+---------------------+
| id | name               | views | created_at          |
+----+--------------------+-------+---------------------+
|  1 | Python3 基础教程    |   981 | 2019-03-18 13:52:03 |
|  2 | JavaScript基础教程  |    73 | 2019-03-18 16:03:32 |
|  3 | Ruby 基础教程       |   199 | 2019-04-01 06:16:14 |
|  4 | SQL 基础教程        |   533 | 2019-05-02 08:13:42 |
+----+--------------------+-------+---------------------+
4 rows in set (0.00 sec)

特别提醒:

更新记录时要格外小心

在上面的示例中,如果省略了 where 子句,如下所示

update lesson set name='Python3 基础教程';

执行以上代码会将 lesson 表中所有数据的 name 改为 Python 3 基础教程

mysql> update lesson set name='Python3 基础教程';
Query OK, 3 rows affected (0.01 sec)
Rows matched: 4  Changed: 3  Warnings: 0
mysql> select * from lesson;
+----+------------------+-------+---------------------+
| id | name             | views | created_at          |
+----+------------------+-------+---------------------+
|  1 | Python3 基础教程 |   981 | 2019-03-18 13:52:03 |
|  2 | Python3 基础教程 |    73 | 2019-03-18 16:03:32 |
|  3 | Python3 基础教程 |   199 | 2019-04-01 06:16:14 |
|  4 | Python3 基础教程 |   533 | 2019-05-02 08:13:42 |
+----+------------------+-------+---------------------+
4 rows in set (0.00 sec)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值