MySql如何通过查询结果集更新数据

52次阅读
没有评论

共计 1096 个字符,预计需要花费 3 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章将为大家详细讲解有关 MySql 如何通过查询结果集更新数据,丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

表结构

 现在有用户表和用户实名认证表,user_info,user_card。user_info 中的字段有 user_id,user_name。user_card 中的字段有 user_id,user_card,user_name。其中 user_name 为用户实名认证的信息,user_info 中做了字段冗余。

问题

 用户表 user_info 中的 user_name 和 user_card 中的 user_name 不同步。user_card 中有值,user_info 中没有值。需要将 user_card 中的 user_name 同步到 user_info 中去。

解决方法

1. 通过代码查询出 user_info 中 user_name 为空的数据 , 然后通过 user_id 查询出用户实名认证的数据进行同步。

select user_id from user_info where user_name = 
 select * from user_card where user_id in (上面的结果集) ;
 通过代码更新数据 

2. 联表查询后更新数据

SELECT
 c.user_id ,
 c.user_name
 FROM
 user_info AS u
 LEFT JOIN user_card AS c ON u.user_id = c.user_id
 WHERE
 u.user_name = 
 通过代码更新数据 

3. 通过 MySql 内联更新数据

 先写出更新语句
 UPDATE `user_info` as u SET u.user_name = 结果集 
 再获取条件结果集
 SELECT
 c.user_id ,
 c.user_name
 FROM
 user_info AS u
 LEFT JOIN user_card AS c ON u.user_id = c.user_id
 WHERE
 u.user_name = 
 最后内联更新
 UPDATE `user_info` as u
 INNER JOIN
 SELECT
 c.user_id ,
 c.user_name
 FROM
 user_info AS u
 LEFT JOIN user_card AS c ON u.user_id = c.user_id
 WHERE
 u.user_name = 
 ) as r ON u.user_id = r.user_id SET u.user_name = r.user_name ;

关于 MySql 如何通过查询结果集更新数据就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向 AI 问一下细节

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-18发表,共计1096字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)