簡體   English   中英

在SQL中,如何獲取具有特定列值的行(如果有),否則如何獲取其他行

[英]In SQL, how do I fetch a row with a specific column value if available, otherwise any other row

我目前有以下產品表:

Product
_______
id, INT
name, String
featured, ENUM(Y, N)

如果上面有特色產品,我將退還該產品。 如果以上都不是,我將退還其中任何一個。 我目前有以下功能正常的查詢:

SELECT *
FROM Product
WHERE (featured = 'Y' OR featured = 'N')
LIMIT 1

有人對上述SQL有異議嗎,感覺有點不對勁? 如果是這樣,最好的方法是什么? 上面是更大查詢的最簡單情況。 我本可以使用ORDER BY精選商品,但是在將精選商品推到我的清單的頂部時,它什么也沒做。

這應該做。 您將“ Y”值強制設置為列表頂部。

SELECT *
FROM Product
ORDER BY CASE WHEN featured = 'Y' THEN 0 ELSE 1 END
LIMIT 1

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM