您好,欢迎来到[编程问答]网站首页   源码下载   电子书籍   软件下载   专题
当前位置:首页 >> 编程问答 >> MYSQL >> sql subquery return more than 1 row

sql subquery return more than 1 row

来源:网络整理     时间:2016/8/29 1:29:02     关键词:

关于网友提出的“ sql subquery return more than 1 row”问题疑问,本网通过在网上对“ sql subquery return more than 1 row”有关的相关答案进行了整理,供用户进行参考,详细问题解答如下:

问题: 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:

any 相当 in()

解决方案2:

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


以上介绍了“ sql subquery return more than 1 row”的问题解答,希望对有需要的网友有所帮助。
本文网址链接:http://www.codes51.com/itwd/3647065.html

相关图片

相关文章