MySQL 更新内连接表查询
在尝试使用 MySQL 中的内连接更新多个表时,用户可能会遇到编译错误。具体来说,以下查询会在 MySQL 5.0 中导致编译错误:
UPDATE b SET b.mapx = g.latitude, b.mapy = g.longitude FROM business AS b INNER JOIN business_geocode g ON b.business_id = g.business_id WHERE (b.mapx = '' OR b.mapx = 0) AND g.latitude > 0
要解决此问题,请按如下方式重新排列查询:
UPDATE business AS b INNER JOIN business_geocode AS g ON b.business_id = g.business_id SET b.mapx = g.latitude, b.mapy = g.longitude WHERE (b.mapx = '' or b.mapx = 0) and g.latitude > 0
请注意,上述查询在语法上是这样的正确的。但是,当针对 MySQL 5.5.8 中的现有表测试查询时,没有行受到影响。这可能是一个不同的问题,需要根据涉及的具体数据和表结构进行进一步调查。
以上是如何使用 INNER JOIN 正确更新多个 MySQL 表?的详细内容。更多信息请关注PHP中文网其他相关文章!