關于Mysql判斷是否存在滿足某一條件的記錄
問題描述
需求
查詢哪些用戶存在有效的優惠券 即仍未使用且未過期
假如是查詢一個用戶的話 SQL
select 1 from user_coupon where status = ’未使用’ and current_date<=ovre_date and user_id = ’XXX’ limit 1;
只要有任一行記錄滿足條件的話即返回1, 表示存在可用的優惠券,無需查詢出該用戶所有的有效優惠券記錄
如果用java表述的話 相當于
for(UserCoupon e : list){ if(e.status == 未使用 && currentDate <= e.overDate){return true; }}
但假如查詢條件是一個用戶ID列表呢? 這時好像只能用distinct或group by了,必須要先查詢出所有記錄了, 沒辦法做到limit 1了
select distinct user_id from user_coupon where ... and user_id in (XXX,XXX,XXX);selec user_id from user_coupon where ... and user_id in (XXX,XXX,XXX) group by user_id;
查詢條件為列表的情況下 有沒辦法指定只要有一條記錄滿足條件即返回 無需查詢所有 這樣的話 也省了用distinct和group by了
問題解答
回答1:沒太看懂問題。如果查詢條件是列表的話,你希望返回結果是所有至少有一張優惠券的用戶嗎?如果是的話,這樣寫:select user_id, count(1) as c from user_coupon where ... group by user_id having c > 0 order by null如果百萬級以下的表,速度應該可以接受,但表比較大的情況下可能有性能問題,建議用explain分析一下。
相關文章:
1. 一個走錯路的23歲傻小子的提問2. python - 請問matplotlib.pyplot.save的路徑如何更改3. python中的 + 不能和java一樣作為連接符么?4. python小白,問一個關于可變類型和不可變類型底層的問題5. python - Django前臺url未能正確訪問方法求助?6. mysql - SQL問個基礎例子,書上的,我怎么看都看不懂..誰幫我解釋一下第2個為什么和第1個一樣?7. python - Django問題 ’WSGIRequest’ object has no attribute ’user’8. javascript - js 對中文進行MD5加密和python結果不一樣。9. 數據庫 - mysql boolean型無法插入true10. mysql服務無法啟動1067錯誤,誰知道正確的解決方法?
