mysql - sql subquery return more than 1 row
问题描述
update orders_father set ostatus=5,ofintimesys=now() where oid =(select oid from(SELECT oid FROM orders_father where TIMESTAMPDIFF(HOUR,odlvtime,now())>parameter and ostatus=4)as tempTable);
这是代码1。
update orders_father set ostatus=5,ofintimesys=now() where oid =any(select oid from(SELECT oid FROM orders_father where TIMESTAMPDIFF(HOUR,odlvtime,now())>parameter and ostatus=4)as tempTable);
这是代码2,在oid=后面增加了any
我的疑问是,为何代码1会出现Error Code: 1242. Subquery returns more than 1 row这种错误,而代码2不会? 谢谢各位大神
背景:我是在存储过程中使用的...
问题解答
回答1:where xxx = yyy的时候,右边必须是单一的值,不能是多个值,而你第一个语句里面的
(SELECT oid FROM orders_father where TIMESTAMPDIFF(HOUR,odlvtime,now())>parameter and ostatus=4)as tempTable)
会查出多个值,所以报Error Code: 1242. Subquery returns more than 1 row的错误
解决的方法就是把where xxx = yyy变成where xxx in(yyy)或者where xxx = any yyy,这两个表达是一个意思,不过any还可以其他的比较,比如where xxx > any yyy
回答2:any 相当 in()
相关文章:
1. 这是什么情况???2. Android明明可以直接分享,为什么还要用微信开放平台、微博开放平台的sdk?3. 服务器上nginx无法访问html的配置问题4. python - oslo_config5. javascript - 单页面应用怎么监听ios微信返回键?6. angular.js - 在ionic下,利用javascript导入百度地图,pc端可以显示,移动端无法显示7. javascript - d3可以自动双向绑定吗?8. javascript - vue中怎么使用原生js插件9. html5 - 如何让背景图在手机端全屏显示(内容比较长,有滚动条),保证图片不变形的情况?10. javascript - js 有什么优雅的办法实现在同时打开的两个标签页间相互通信?
