国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

mysql - sql subquery return more than 1 row

瀏覽:127日期:2022-06-18 18:54:31

問題描述

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()

相關文章:
主站蜘蛛池模板: 苍溪县| 嘉善县| 灵璧县| 内乡县| 通许县| 綦江县| 建水县| 延安市| 济源市| 安阳市| 罗江县| 宁南县| 托克逊县| 郯城县| 亳州市| 家居| 新龙县| 岱山县| 金沙县| 泗阳县| 隆林| 汤原县| 潞西市| 德令哈市| 万荣县| 潍坊市| 武冈市| 盐亭县| 洱源县| 贵港市| 钟祥市| 城口县| 吉安市| 同江市| 黎平县| 潜山县| 布尔津县| 铅山县| 景洪市| 台南县| 武定县|