從 MySQL 中另一張表更新單張表中的資料?


為此,你可以將 UPDATE 命令與 JOIN 一起使用。

讓我們建立第一張表 -

mysql> create table demo54
−> (
−> firstName varchar(20),
−> lastName varchar(20)
−> );
Query OK, 0 rows affected (0.57 sec)

使用 insert 命令在表中插入一些記錄 -

mysql> insert into demo54 values('John','Smith');
Query OK, 1 row affected (0.09 sec)

mysql> insert into demo54 values('John','Smith');
Query OK, 1 row affected (0.09 sec)

mysql> insert into demo54 values('David','Smith');
Query OK, 1 row affected (0.11 sec)

使用 select 語句從表中顯示記錄 -

mysql> select *from demo54;

這將產生以下輸出 -

+-----------+----------+
| firstName | lastName |
+-----------+----------+
| John      | Smith    |
| John      | Smith    |
| David     | Smith    |
+-----------+----------+
3 rows in set (0.00 sec)

以下是建立第二張表的查詢 -

mysql> create table demo55
−> (
−> firstName varchar(20),
−> lastName varchar(20)
−> );
Query OK, 0 rows affected (1.93 sec)

使用 insert 命令在表中插入一些記錄 -

mysql> insert into demo55 (firstName) values('John');
Query OK, 1 row affected (0.10 sec)

mysql> insert into demo55 (firstName) values('David');
Query OK, 1 row affected (0.13 sec)

mysql> insert into demo55 (firstName) values('Bob');
Query OK, 1 row affected (0.10 sec)

使用 select 語句從表中顯示記錄 -

mysql> select *from demo55;

這將產生以下輸出 -

+-----------+----------+
| firstName | lastName |
+-----------+----------+
| John      | NULL     |
| David     | NULL     |
| Bob       | NULL     |
+-----------+----------+
3 rows in set (0.00 sec)

以下是從另一張表更新單張表中的資料的查詢。

mysql> UPDATE demo55 tbl1
−> JOIN demo54 tbl2 ON tbl1.firstName = tbl2.firstName
−> set tbl1.lastName = tbl2.lastName;
Query OK, 2 rows affected (0.10 sec)
Rows matched: 2 Changed: 2 Warnings: 0

使用 select 語句從表中顯示記錄 -

mysql> select *from demo55;

這將產生以下輸出 -

+-----------+----------+
| firstName | lastName |
+-----------+----------+
| John      | Smith    |
| David     | Smith    |
| Bob       | NULL     |
+-----------+----------+
3 rows in set (0.00 sec)

更新於: 20-十一月-2020

1 千+ 瀏覽次數

開啟你的職業

透過完成課程獲得認證

開始
廣告