仅使用“a”和“b”值在 MySQL 列中用“b”更新“a”记录,用“a”更新“b”记录(交换)?


为此,请使用 CASE 语句。让我们首先创建一个表 -

mysql> create table DemoTable
(
   Value char(1)
);
Query OK, 0 rows affected (1.21 sec)

使用插入命令在表中插入一些记录 -

mysql> insert into DemoTable values('a');
Query OK, 1 row affected (0.16 sec)
mysql> insert into DemoTable values('b');
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable values('a');
Query OK, 1 row affected (0.09 sec)
mysql> insert into DemoTable values('a');
Query OK, 1 row affected (0.11 sec)
mysql> insert into DemoTable values('b');
Query OK, 1 row affected (0.09 sec)
mysql> insert into DemoTable values('a');
Query OK, 1 row affected (0.11 sec)
mysql> insert into DemoTable values('b');
Query OK, 1 row affected (0.13 sec)

使用 select 语句显示表中的所有记录

mysql> select *from DemoTable;

这将产生以下输出 -

+-------+
| Value |
+-------+
| a     |
| b     |
| a     |
| a     |
| b     |
| a     |
| b     |
+-------+
7 rows in set (0.00 sec)

以下是使用“b”更新“a”记录并使用“a”更新“b”的查询 -

mysql> update DemoTable set Value=case when Value='a' then 'b' else 'a' end;
Query OK, 7 rows affected (0.17 sec)
Rows matched: 7 Changed: 7 Warnings: 0

让我们再次检查表记录 -

mysql> select *from DemoTable;

这将产生以下输出 -

+-------+
| Value |
+-------+
| b     |
| a     |
| b     |
| b     |
| a     |
| b     |
| a     |
+-------+
7 rows in set (0.00 sec)

更新时间: 25-9-2019

370 次浏览

开启你的职业生涯

完成课程,获得认证

开始使用
广告