Heim  >  Fragen und Antworten  >  Hauptteil

MySQL So wählen Sie ein Datum aus einem Feld vom Typ „Datum/Uhrzeit“ aus

Es gibt ein Feldcreated_atvom Typ Datum/Uhrzeit. Wie wähle ich die Daten eines bestimmten Datums aus?

SELECT * FROM data WHERE created_at = '2017-06-29';
SELECT * FROM data WHERE created_at BETWEEN '2017-06-29 00:00:00' AND '2017-06-29 23:59:59';

Keine davon ist korrekt, die Ergebnismengen sind alle leer

某草草某草草2668 Tage vor960

Antworte allen(5)Ich werde antworten

  • 曾经蜡笔没有小新

    曾经蜡笔没有小新2017-06-30 09:55:42

    参考文章:MySQL时间处理相关函数

    WHERE DATE(created_at) = '2017-06-29'

    或是

    WHERE created_at LIKE '2017-06-29%'

    Antwort
    0
  • 習慣沉默

    習慣沉默2017-06-30 09:55:42

    datetime默认格式'2017-06-29 00:00:00' 如果你的数据这一天确实有数据的话第二条是会有结果的,所以首先你要看一下是不是表中有这一天的数据并且你的数据格式是什么样的

    PS:取某一天的数据可以created_at like 'yyyy-mm-dd%'或者就是你第二种写法,date(created_at)、left(created_at)也可以取到当天的日期,但是都不会走索引,效率很差

    Antwort
    0
  • 仅有的幸福

    仅有的幸福2017-06-30 09:55:42

    我的可以,可能是你的表或者字段错了,或者确实没有结果。。条件是没问题的

    Antwort
    0
  • 高洛峰

    高洛峰2017-06-30 09:55:42

    select * from data d WHERE d.created_at >= curdate()
    and d.created_at < DATE_ADD(STR_TO_DATE(curdate(), '%Y-%m-%d'), INTERVAL 1 DAY);

    意思就是查询大于等于今天零时小于明天零时的时间

    Antwort
    0
  • 黄舟

    黄舟2017-06-30 09:55:42

    第一行不对, 因为datetime和你条件里面的格式不一样.

    第二行是对的.
    结果也是对的, 因为确实没数据.

    Antwort
    0
  • StornierenAntwort