MySQL TIMESTAMP 類型加索引時出現的bug

來源:互聯網
上載者:User

標籤:end   dstat   解決   mkt   stat   begin   刪掉   資料   java   

    資料庫:MySQL,版本:5.1.45

    查詢語句1:

    select id, settlement_begin_time , settlement_end_time  from mkt_vendor_settlement_brief where settlement_begin_time >= ‘2017-09-01 00:00:00.0‘ and settlement_end_time <=  ‘2017-09-30 23:59:59.0‘;

    結果:

    

    查詢語句2:

    select id, settlement_begin_time , settlement_end_time  from mkt_vendor_settlement_brief where settlement_begin_time >= ‘2017-09-01 00:00:00‘ and settlement_end_time <=  ‘2017-09-30 23:59:59.0‘

    結果:

    

     對settlement_begin_time 添加了索引,查詢語句的區別: 一個有".0"一個沒有“.0”

     刪掉索引後有".0"的也能正常查詢。

     經調查,這是MySQL的一個bug,在後續版本中已經修複,本人使用mysql5.5進行測試一切正常。

     出現此問題時的解決方案:

      1.  升級MySQL版本,最有效

      2. 曲線救國,Java代碼中,預先將Timestamp類型的資料進行格式化,然後以字串的方式放入查詢語句,因為mysql-jdbc調用的  “PreparedStatement” 的setTimestamp方法會加上".0"

MySQL TIMESTAMP 類型加索引時出現的bug

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.