搜索

首页  >  问答  >  正文

mysql - 关联数据表的更新问题

UPDATE a,b SET a.v_publishyear = b.v_publishyear WHERE a.v_id = b.v_e

我想更新a表中的数据,实际应该有9000多条数据,而实际上只能更新120条数据。这是怎么回事。
把b表中publishyear字段更新到对应的a表publishyear字段中.

但是当我进行操作

SELECT * FROM a表,b表 where a表.c字段 = b表.d字段
这个查询的时候,可以查询到全部的9000多条数据,这是怎么回事
我更新数据代码哪里出错了呢?

天蓬老师天蓬老师2743 天前680

全部回复(2)我来回复

  • 怪我咯

    怪我咯2017-05-27 17:41:06

    UPDATE不太适合用WHERE去关联两表。所以试试这种写法:

    UPDATE a LEFT JOIN b ON a.v_id = b.v_e SET a.v_publishyear = b.v_publishyear

    回复
    0
  • 伊谢尔伦

    伊谢尔伦2017-05-27 17:41:06

    雷雷

    回复
    0
  • 取消回复