qq_19390245 2022-03-29 11:59 采纳率: 33.3%
浏览 88
已结题

如何查询mysql两个表联查后有相同字段的更新另外字段值

问题遇到的现象和发生背景

现有2个表,分别为:
data_1014(data_id,fd64)
data_1018(data_n_id,data_id,fd70)

说明:
1、data_1018中的data_id等于data_1014中的data_id
2、data_1014中的data_id是唯一的,不重复。
3、data_1018中的data_id是重复的,有多条。

运行结果及报错内容

子查询有多条数据

我的解答思路和尝试过的方法

UPDATA DATA_1018 SET FD70 = (SELECT FD64 FROM DATA_1014)

我想要达到的结果

只要是data_1018的data_id=data_1014的data_id,那么就update更新 fd70=fd64。

img

  • 写回答

4条回答 默认 最新

  • CSDN专家-sinJack 2022-03-29 13:17
    关注

    用ifnull函数判断查询的结果是否为空,为空则设置为原来的值,否则修改。

    UPDATA DATA_1018 t1 SET FD70 = ifnull((SELECT FD64 FROM DATA_1014 where t1.data_id=data_id),FD70);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 4月6日
  • 已采纳回答 3月29日
  • 修改了问题 3月29日
  • 修改了问题 3月29日
  • 展开全部

悬赏问题

  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)