gpt4 book ai didi

mysql - 使用 where & CONCAT 问题更新 Select

转载 作者:行者123 更新时间:2023-11-29 10:41:44 25 4
gpt4 key购买 nike

我试图在连接两列后用另一个表数据更新一个表,它显示错误。

Error Code: 1064. You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax

表1:订单表2:用户

我正在尝试通过将订单表中的字段与 user_id 进行比较来更新订单表字段 name

user_id 链接到用户表。我正在尝试连接 first_namelast_name 并更新订单表中的 name

UPDATE orders SET 
(name =
SELECT CONCAT(u.first_name, ' ', u.last_name) as full_name
FROM users u
WHERE u.first_name IS NOT NULL OR u.first_name <> '' );

情况是这样的。

如果订单表中的user_id中存在任何ID,则应检查usersid并选择并连接first_name & last_name 并更新订单表。

如果订单表中没有 user_id,则该字段应更新为 NONE

通过查询来完成此操作对我来说很复杂。我可以在 PHP 中做到这一点,但不推荐。有人可以帮忙吗?

最佳答案

假设您的订单表上有一个 user_id 列要加入,您可以尝试以下操作:

UPDATE orders o SET o.name = 
IFNULL((SELECT CONCAT(u.first_name, ' ', u.last_name) AS full_name
FROM users u
WHERE u.user_id = o.user_id
AND u.first_name IS NOT NULL
AND u.first_name <> ''), 'NONE');

关于mysql - 使用 where & CONCAT 问题更新 Select,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45345878/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com