免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1839 | 回复: 6
打印 上一主题 下一主题

一个可以在mssql上运行的sql在mysql上失败 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-08 10:48 |只看该作者 |倒序浏览
一个sql语句:
UPDATE .....
SET ........
FROM .....(有两个表)
WHERE ..... AND ....(两个表有连接)
这个可以在 MS SQL Server 上面正常运行
但是在Mysql上面会出错
我已经google过了,知道mysql不支持这种语句。
当时为了赶进度,就使用php完成了上述功能,如下:
SELECT .....
FROM ....
WHERE ..... AND ....
然后再
UPDATE .....
SET ........
WHERE .....

但是我还是不知道如何用mysql支持的sql语句完成上述功能
请教了!谢谢!

论坛徽章:
0
2 [报告]
发表于 2008-07-08 11:30 |只看该作者
用php实现了就行了, 向前看, 不要在这个问题上纠缠了.

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
3 [报告]
发表于 2008-07-08 11:59 |只看该作者
参考一下吧

UPDATE T1 SET BB = (SELECT DISTINCT T2.CC FROM T1,T2 WHERE T1.AA=T2.AA)  WHERE  BB = "");

这个是上次给一个网友的回复他说是好用的

论坛徽章:
0
4 [报告]
发表于 2008-07-08 13:20 |只看该作者
两个表应该写在set的前面

论坛徽章:
0
5 [报告]
发表于 2008-07-08 16:08 |只看该作者
谁说不可以,打他屁股
Multiple-table syntax:

UPDATE [LOW_PRIORITY] [IGNORE] table_references
    SET col_name1=expr1 [, col_name2=expr2 ...]
    [WHERE where_condition]

论坛徽章:
0
6 [报告]
发表于 2008-07-08 16:45 |只看该作者
To2楼:
      只是为了学习^_^
谢谢各位了!
问题解决了
UPDATE `x` ,`y`
SET `x`.`m` = `y`.`m`
WHERE `x`.`n` = `y`.`n` AND `y`.`c` = sk'

论坛徽章:
0
7 [报告]
发表于 2008-07-10 12:46 |只看该作者
See multiple update syntax on the official document.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP