av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

mysql - sql subquery return more than 1 row

瀏覽:111日期: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()

相關文章:
主站蜘蛛池模板: 久久伦理中文字幕 | 国产精品精品视频一区二区三区 | 韩日一区二区三区 | 精品成人69xx.xyz | 欧美久久精品一级黑人c片 91免费在线视频 | 亚洲在线日韩 | 老头搡老女人毛片视频在线看 | 鸳鸯谱在线观看高清 | 国产超碰人人爽人人做人人爱 | 亚洲一区免费 | 天天干夜夜操视频 | 中文字幕在线看人 | 久久久精品在线 | 精品一区二区三区在线观看 | 先锋资源站 | 澳门永久av免费网站 | 国产一区中文字幕 | 国产激情一区二区三区 | 亚洲视频免费在线播放 | 成人av在线播放 | 欧美日在线 | 国产成人一区在线 | 欧美精品久久 | 九九九视频在线 | 毛片高清 | 免费在线播放黄色 | 日本小电影在线 | 天天操狠狠操 | 国产高清一区二区三区 | 精品国产一区二区三区性色av | 青青草精品 | 亚洲欧美日韩精品久久亚洲区 | 成人在线免费视频 | 黄色在线观看 | 91精品国产91久久久久久密臀 | 久草综合在线视频 | av中文字幕网| 中文字幕三区 | 性欧美精品一区二区三区在线播放 | 精品欧美一区二区在线观看欧美熟 | 久久在线|