在MySQL中从另一个表中的数据更新一个表中的数据?

为此,您可以将UPDATE命令与JOIN一起使用。

让我们创建第一个表-

mysql> create table demo54

−> (

−> firstName varchar(20),

−> lastName varchar(20)

−> );

借助insert命令将一些记录插入表中-

mysql> insert into demo54 values('John','Smith');

mysql> insert into demo54 values('John','Smith');

mysql> insert into demo54 values('David','Smith');

使用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)

−> );

借助insert命令将一些记录插入表中-

mysql> insert into demo55 (firstName) values('John');

mysql> insert into demo55 (firstName) values('David');

mysql> insert into demo55 (firstName) values('Bob');

使用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;

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)

以上是 在MySQL中从另一个表中的数据更新一个表中的数据? 的全部内容, 来源链接: utcz.com/z/345289.html

回到顶部