• 技术文章 >数据库 >mysql教程

    mysql可以做日期处理吗

    青灯夜游青灯夜游2020-10-07 12:40:24原创69

    mysql可以做日期处理;它可以利用CURDATE()、NOW()、YEAR()、MONTH()、DAY()、HOUR()、MINUTE()、SECOND()等内置函数来做日期处理,例“SELECT CURDATE()”获取当前日期。

    最近一个项目,需要写很多的sql语句。涉及到很多与时间相关的处理,现在做一下简单的总结。

    1.时间格式:在这个项目中,或许是由不同的人建立的数据库表结构吧,对时间的格式步统一,有的表中存储的long类型的时间戳,有的表中是存储的日期,有的表中存储的是时间,同时格式有20171225,2017-12-25等,一点都不统一。这样做,会对项目增加一些额外的工作量,同时会衍生出一些问题出来。比如,在写后台代码时,需要对时间做出处理,以适应数据库的时间格式;在进行夺标联合查询时,时间格式不统一,又会对sql语句进行时间格式转换,造成sql语句臃肿的情况。所以,在同一个项目中,时间格式应该保持统一。个人觉得long 类型的时间戳,以及String类型的yyyy-MM-dd HH:mm:ss 这两种方式时比较不错的。

    long类型的时间戳,是因为后台java代码将date类型的时间转化为时间戳很容易。

    String类型时因为,我们假如经常使用时间这个字段,在应用时不需要额外将Date类型转化为String类型,使用起来比较直观,方便。

    2.常用时间语句

    SELECT  CURDATE():2020-10-7  //此时日期
    SELECT  NOW() : 2020-10-7 22:20:21  //此刻时间
    SELECT  YEAR('2020-10-7 22:27:45'): 2020 //获取时间的年份
    SELECT  MONTH('2020-10-7 22:27:45'): 10 //获取时间的月份
    SELECT  DAY('2020-10-7 22:27:45'):25  //获取时间的天数
    SELECT  HOUR('2020-10-7 22:27:45'):22  //获取时间的小时
    SELECT  MINUTE('2020-10-7 22:27:45'):27  //获取时间的分钟
    SELECT  SECOND('2020-10-7 22:27:45'):45  //获取时间的秒数
    SELECT  DATE_SUB(NOW(),INTERVAL   1   YEAR)  //在目前的时间减去一年,该语句可以进行多种操作,指定时间下减去x年:DATE_SUB("2017-12-25",INTERVAL x YEAR),同时可以减去 x month/day/hour/minute/second等
    SELECT  DATE_ADD(NOW(),INTERVAL 1 YEAR)  //同上,在目前的时间上加上一年
    SELECT  CONCAT('2017','-12-12'):2017-12-12  //组装字符串,可以组装成任何时间格式,也可以使用如上语句,例如:SELECT CONCAT(YEAR(NOW()),'-12-12') :2017-12-12 ;
    SELECT UNIX_TIMESTAMP('2017-12-25'):1514131200  //字符串转换成时间戳
    SELECT FROM_UNIXTIME(1514131200) :2017-12-25 00:00:00  //时间戳转化为时间
    SELECT DATE_FORMAT('2017-12-25 22:23:01', '%Y-%m-%d %H:%i:%s');   //字符串转化为时间格式(date),也可以时间格式转化为字符串格式

    以上就是在mysql中比较常用的一些时间相关的语句。

    推荐教程:mysql视频教程

    以上就是mysql可以做日期处理吗的详细内容,更多请关注php中文网其它相关文章!

    本文原创发布php中文网,转载请注明出处,感谢您的尊重!
    专题推荐:mysql
    上一篇:mysql建表外键怎么设? 下一篇:mysql子条件查询语句是什么意思?
    第13期线上培训班

    相关文章推荐

    • mysql怎么批量删除多个表?• php 查询mysql乱码怎么办• mysql用什么代替in• mysql文件储存在哪里?怎么查看路径?• 怎么修改mysql的表名和列名?• mysql怎么查询表中所有列(字段)?• mysql的注释有几种写法?• unbuntu如何彻底删除mysql?

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网