神秘的 mysql 匹配問題:揭秘日期比較和隨機月份
复制代码
- select * from teacher where date_format(date_add('2023-11-01',interval floor(rand() * datediff (curdate(), '2023-11-01')) day),'%y-%m') = date_format(create_time, '%y-%m');
登錄后復制
目標是查詢從給定月份到現在的時間段內,隨機選取某個月的數據。然而,結果卻令人疑惑。
問題根源在于隨機月份部分的 sql 語句。每次執行查詢時,rand 函數都會重新計算,導致每次隨機月份不同。為了解決此問題,可以利用 mysql 8 的 with 語句:
复制代码
- with mo1 as (select DATE_FORMAT(DATE_ADD('2023-11-01', INTERVAL FLOOR(RAND() * DATEDIFF(CURDATE(), '2023-11-01')) DAY), '%Y-%m') as month) SELECT * FROM teacher join mo1 on mo1.month = DATE_FORMAT(create_time, '%Y-%m')
登錄后復制
雖然這解決了問題,但還有更優化的方案:
- 避免使用函數索引:函數索引的性能并不理想,不如直接為 create_time 列創建索引。
- 使用外部參數:將隨機月份作為外部參數傳入,而不是在 sql 語句中計算。
- 使用 between 比較:將創建日期范圍補全,使用 between 比較,并為 create_time 列創建索引。
通過這些優化,可以顯著提高 mysql 查詢效率,避免不必要的困惑。