使用 MySQL WHERE 子句更新多个值


首先,让我们创建一个表格 −

mysql> create table DemoTable
   -> (
   -> Id int,
   -> Name varchar(20),
   -> Age int,
   -> CountryName varchar(10)
   -> );
Query OK, 0 rows affected (0.81 sec)

使用“insert”命令在表格中插入一些记录 −

mysql> insert into DemoTable values(100,'Chris',34,'AUS');
Query OK, 1 row affected (0.21 sec)
mysql> insert into DemoTable values(101,'Chris',31,'US');
Query OK, 1 row affected (0.21 sec)
mysql> insert into DemoTable values(102,'David',25,'UK');
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable values(103,'Carol',28,'AUS');
Query OK, 1 row affected (0.21 sec)

使用“select”语句显示表格中的所有记录 −

mysql> select * from DemoTable;

这将产生以下输出 −

+------+-------+------+-------------+
| Id   | Name  | Age  | CountryName |
+------+-------+------+-------------+
|  100 | Chris |   34 | AUS         |
|  101 | Chris |   31 | US          |
|  102 | David |   25 | UK          |
|  103 | Carol |   28 | AUS         |
+------+-------+------+-------------+
4 rows in set (0.00 sec)

这是使用 WHERE 子句更新多个值的查询 −

mysql> update DemoTable
   -> set Name='Robert'
   -> where Age=31 and CountryName='US';
Query OK, 1 row affected (0.44 sec)
Rows matched: 1 Changed: 1 Warnings: 0

让我们再次检查表格记录 −

mysql> select * from DemoTable;

这将产生以下输出 −

+------+--------+------+-------------+
| Id   | Name   | Age  | CountryName |
+------+--------+------+-------------+
|  100 | Chris  |   34 | AUS         |
|  101 | Robert |   31 | US          |
|  102 | David  |   25 | UK          |  
|  103 | Carol  |   28 | AUS         |
+------+--------+------+-------------+
4 rows in set (0.00 sec)

更新时间: 2020-02-28

1K+ 浏览

开启你的 职业生涯

完成课程后获得认证

开始
广告