久综合色-久综合网-玖草影视-玖草资源在线-亚洲黄色片子-亚洲黄色片在线观看

Hello! 歡迎來到小浪云!


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


avatar
小浪云 2024-11-11 172

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

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

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

复制代码
  1. 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 語句:

复制代码
  1. 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国内视频| 免费一级肉体全黄毛片高清 | 国产一级在线观看 | 国产精品三级在线播放 | 欧美一区二区三区免费看 | a中文字幕1区 | 免费国产成人午夜在线观看 | 成人影视免费 | 多人伦精品一区二区三区视频 | 成人精品一区二区不卡视频 | 国产九九在线观看播放 | 视频二区精品中文字幕 | 国产精品无圣光一区二区 | 高级毛片 | 成人三级在线播放线观看 | 欧美亚洲一区 | 亚洲天堂网在线观看视频 | 久草在线免费看 | 亚洲欧美日韩国产制服另类 | 亚洲免费高清 | 成人看片黄a毛片 | 亚洲精品久久久久久久网站 | 在线看国产视频 | 国产首页精品 | 华人黄网站 | 99久久精品毛片免费播放 | 久久久久亚洲精品中文字幕 | 91久久香蕉| 久久久久国产精品免费免费 | 久久久精品视频免费观看 | 国产日本三级欧美三级妇三级四 | 欧洲一级毛片 | 怡红院视频网 | 亚洲免费中文 |