日韩天堂,国产精品久久久久久久久久一区,羞羞羞网站,自拍视频网站,久久亚洲欧美成人精品,桃花阁成人网在线观看

Hello! 歡迎來到小浪云!


MySQL 日期比較和隨機月份的困惑:為什么我的 SQL 查詢結果總是變化?


avatar
小浪云 2024-11-11 229

MySQL 日期比較和隨機月份的困惑:為什么我的 SQL 查詢結果總是變化?

神秘的 mysql 匹配問題:揭秘日期比較和隨機月份

mysql 中,一則詭異的 sql 查詢引起了困擾:

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 查詢效率,避免不必要的困惑。

相關閱讀

主站蜘蛛池模板: 黄色激情影院 | 插寡妇| 亚洲欧美一区二区三区在线观看 | 国产在线观看一区 | 久久网精品视频 | 永久免费在线视频 | 中文字幕一级毛片 | 禁网站在线观看免费视频 | 99久久精品免费看国产一区二区三区 | 亚洲欧美国产一区二区三区 | 精品视频一区二区观看 | 四虎影院在线免费 | 亚洲午夜在线观看 | 在线色网址 | 噜噜噜在线视频免费观看 | 国产成人综合久久精品亚洲 | 亚洲欧美综合 | 日韩第四页 | 国产欧美精品系列在线播放 | 国内自拍中文字幕 | 亚洲欧美一区二区三区在线播放 | 日韩一区二区精品久久高清 | 99久久精品国产一区二区成人 | 亚洲欧美偷拍另类 | 羽月希母乳 | 亚洲阿v天堂2021在线观看 | 日本视频中文字幕一区二区 | 亚洲国产成人久久99精品 | 国产成人精品免费久久久久 | 国产视频一区在线观看 | 国产一区精品视频 | 在线不卡福利 | 亚洲男人天堂手机版 | 国色天香社区在线看免费 | 国产精品麻豆网站 | 日韩成人中文字幕 | 久热国产在线视频 | 亚洲一区二区在线视频 | 丁香综合五月 | 亚洲精品tv久久久久久久久 | 欧美精品免费专区在线观看 |