mysql中的update语句

因粗心大意,把creature_equip_template表中equipentry1字段里的数据写成了item_template表里displayid字段的数值,本应该... 因粗心大意,把creature_equip_template表中equipentry1字段里的数据写成了item_template表里displayid字段的数值,本应该是写这个表里的entry字段,现在如何用语句将creature_equip_template表中的equipentry1字段替换成item_template表里entry字段,且equipentry1等于displayid. 展开
 我来答
l7722526
2019-07-22 · TA获得超过2.7万个赞
知道大有可为答主
回答量:2.8万
采纳率:84%
帮助的人:3815万
展开全部
sql:update items set price = case id when 1 then 11.0 when 2 then 12.0 when 3 then 13.0 end, lowest = case id when 1 then 'jd' when 2 then 'tmall' when 3 then 'suning' end where id in (1, 2, 3).
php的话,可以用数组来拼出类似上面这样的长sql。
GTA小鸡
高粉答主

2019-07-22 · 醉心答题,欢迎关注
知道大有可为答主
回答量:2.6万
采纳率:78%
帮助的人:1.3亿
展开全部
UPDATE creature_equip_template SET equipentry1=(
SELECT entry FROM item_template WHERE equipentry1=item_template.displayid
);
追问

1242 - Subquery returns more than 1 row
看来是不行

追答
你的equipentry1和displayid不是一对一的关系。item_template表中存在多条displayid相同的记录。
所以,要么先修复数据表,要么使用DISTINICT去重,选择其中某一条记录。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式