V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
uti6770werty
V2EX  ›  问与答

MySQL 的 SELECT,如何让分钟或者秒数来做 WHERE 条件呢?

  •  
  •   uti6770werty · 2020-09-20 12:05:34 +08:00 · 1544 次点击
    这是一个创建于 1523 天前的主题,其中的信息可能已经有所发展或是发生改变。

    InSerttTime 字段是 datetime 类型
    比如,要 SELECT 出 InSerttTime 字段是"2020-03-15 XX:43:XX",要找出当天 43 分的所有字段内容
    如果是指定时、秒,而不指定日期呢?

    8 条回复    2020-09-21 14:57:26 +08:00
    zvcs
        1
    zvcs  
       2020-09-20 12:13:23 +08:00 via iPhone
    ... where minute ( InSerttTime )=‘4’
    coderteddy
        2
    coderteddy  
       2020-09-20 14:03:55 +08:00
    有 format 不会用吗,兄弟
    aguesuka
        4
    aguesuka  
       2020-09-20 17:08:55 +08:00
    在意性能就单独一个字段存。
    不在意就转字符串比较
    oneisall8955
        5
    oneisall8955  
       2020-09-20 17:11:39 +08:00 via Android
    @dovme 有点东西🐶
    virusdefender
        6
    virusdefender  
       2020-09-20 20:18:23 +08:00
    https://dev.mysql.com/doc/refman/8.0/en/date-and-time-functions.html#function_extract

    mysql> SELECT EXTRACT(DAY_MINUTE FROM '2019-07-02 01:02:03');
    -> 20102
    ccalywm
        7
    ccalywm  
       2020-09-21 09:07:24 +08:00
    select InSerttTime from table where InSerttTime regexp '2020-03-15 XX:43:'
    CodeCodeStudy
        8
    CodeCodeStudy  
       2020-09-21 14:57:26 +08:00
    先 SELECT id FROM table_name WHERE InSerttTime >= '2020-03-15' AND InSerttTime < '2020-03-16';
    得到所有符合条件的主键 id,假设得到的是 1,2,3,然后再
    SELECT * FROM table_name WHERE id IN (1,2,3);
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1009 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 22:19 · PVG 06:19 · LAX 14:19 · JFK 17:19
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.