mysql update inner join错误
问题描述
问题解答
回答1:create table tb1( country int, province int, city int);create table tb2( country int, province int, city int);insert into tb1 (country, province, city) values (1, 2, 5), (1, 3, null);insert into tb2 (country, province, city) values (1, 2, 5), (1, 3, 7);select * from tb1;select * from tb2;update tb1inner join tb2 on tb1.country=tb2.country and tb1.province=tb2.provinceset tb1.city=tb2.citywhere tb1.city is null; -- and tb1.xx=?select * from tb1;select * from tb2;
update from 语句在 mssql 中有效, mysql 似乎无法正常执行
update tb1 set city=r.city from (select country, province, city from tb2) as rwhere tb1.city is null and tb1.country=r.country and tb1.province=r.province
http://sqlfiddle.com/#!9/4df7d7/2
相关文章:
1. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE语法实现存在即更新应该使用哪个标签?2. 哭辽 求大佬解答 控制器的join方法怎么转模型方法3. mysql储存json错误4. mysql - 怎么生成这个sql表?5. mysql - 数据库表中,两个表互为外键参考如何解决6. Navicat for mysql 中以json格式储存的数据存在大量反斜杠,如何去除?7. sql语句 - 如何在mysql中批量添加用户?8. mysql - 表名称前缀到底有啥用?9. 编辑成功不显示弹窗10. 怎么php怎么通过数组显示sql查询结果呢,查询结果有多条,如图。
