一、日期相关的数据类型
1、datetime
占用8字节,既显示了日期,又显示了时间。其表示的日期范围为“1000-01-01 00:00:00”到“9999-12-31 23:59:59”
2、date
占用3个字节,可显示的日期范围“1000-01-01”到“9999-12-31”
3、timestamp
和datetime显示结果一样,都是固定的“YYYY-MM-DD 00:00:00“。不同的是timestamp占用4个字节,显示范围为”1970-01-01 00:00:00”UTC到“2038-01-19 03:14:07“UTC。其实际存储的内容为”1970-01-01 00:00:00”到当前时间的毫秒数。在新建表时,列为timestamp类型可以设置一个默认值,而datetime不行。在更新表时,可以设置timestamp类型的列自动更新时间为当前时间
如下
新建表
create table score (
    id int(10) not null primary key,
    bz2 TIMESTAMP DEFAULT CURRENT_TIMESTAMP
)
插入一条数据,不对timestamp类型插入
insert into score (id) VALUES (1)
运行结果如下:timestamp类型自动赋默认值,我们设置的默认值为CURRENT_TIMESTAMP





更新表
create table score (
    id int(10) not null primary key,
   
bz2 TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
)
insert into score (id,bz2) values (1,CURRENT_TIMESTAMP)
结果如下
 
执行update语句 : update score set id=2
 
可以看到bz2的时间自动变为更新表的当前时间
4、year
year类型占用1字节,并且可以在定义的时候指定显示的宽度为year(4)或者year(2)。year(4)显示的范围为1901-2070,year(2)的显示范围为1970-2070,该设置下,00-69代表2000-2069,代表最近的年份
5、time
占3个字节,显示范围为”-838:59:59“-”838:59:59“。为什么time的类型可以大于23,可以为负值,这是因为time不仅可以用来保存一天中的时间,还可以保存时间的间隔。
 
二、日期相关的函数
1、now(),current_timestamp(),sysdate()
执行sql语句:select now(),current_timestamp(),sysdate(),结果如下:


这样,看不出三个有什么区别,然后执行下面的sql语句:
select sleep(2), now(),current_timestamp(),sysdate();其中,sleep(2)代表执行等待2秒
结果如下:


可以看出,now(),current_timestamp()这两个函数结果相同,它们等价,指的是sql开始执行的时间
而sysdate()的结果晚了两秒,代表执行该函数时候的当前时间。
2、时间加减的函数
直接进行now()+1会返回给你一个数字而不是日期,如下:select now()+1
 
那么如何在now的基础上加上一天或者减去一天,这就要用到date_add(date, interval 1 day),date_sub(date, interval 1 day)函数。
用法如下:select now() as today,
date_add(now(), interval 1 day) as tomorrow,
date_sub(now(), interval 1 day) as yestoday
结果如下:


在函数中使用的是day作为间隔时间,也可以使用year,month,week,hour,minute,second等
 
3、date_format()函数
其作用是按照用户需求格式化打印日期
select DATE_FORMAT(NOW(),'%Y%m%d')
其中%Y代表4位的year,%y代表2位的year;%m代表2位的month;%d代表2位的day。其中,%Y,%m,%d之间可以添加任何的字符已达到自己目标。上述格式输出20130915,如果设为’%Y:%m:%d',则输出2013:09:15,如果设为为’%Y/%m/%d',则输出2013/09/15

MySQL中关于日期、时间的数据类型和函数的更多相关文章

  1. MySQL 中的日期时间类型

    日期时间类型中包含以下几种数据类型: DATE TIME DATETIME TIMESTAMP YEAR 各类型都有具体的取值范围,超出或非法的其他值时,MySQL 会回退到 0.TIMESTAMP ...

  2. MYSQL 中常用日期时间函数使用

    MySQL Date 函数 下面的表格列出了 MySQL 中最重要的内建日期函数: 函数 描述 NOW() 返回当前的日期和时间 CURDATE() 返回当前的日期 CURTIME() 返回当前的时间 ...

  3. Oracle中与日期时间有关的运算函数

    1            ADD_MONTHS 格式:ADD_MONTHS(D,N) 说明:返回日期时间D加N月后对应的日期时间.N为正时则表示D之后:N为负时则表示为D之前:N为小数则会自动先删除小 ...

  4. Mysql 中的日期时间字符串查询

    一.将数据库中的Date格式的数据,或者指定日期的字符串格式化为想要的样式 DATE_FORMAT (date, format)能根据格式串format 格式化日期或日期和时间值date,返回结果字符 ...

  5. 开发过程中 的一些 补充知识点 + 关于mysql中的日期和时间函数?

    参考: https://www.jb51.net/article/23966.htm https://yq.aliyun.com/articles/260389 mysql中的 日期格式是: HHHH ...

  6. 在mysql数据库中关于日期时间字段的处理

    在mysql数据库中关于日期时间字段的处理 在开发中,日期时间字段一般有如下几种设计 假设要获取2013-08-15日到2013-08-16日之间的记录 1. 直接使用日期时间类字段 相关sql语句如 ...

  7. MySQL中的日期和时间:使用和说明,以及常用函数

    1.首先需要注意: 1.1 MySQL中把日期和时间是分开的. 以字符串2007-12-31 00:59:59为例: 日期部分:2007-12-31.这部分也可以叫做一个日期表达式. 时间部分:00: ...

  8. MYSQL中关于日期处理的函数

    < DOCTYPE HTML PUBLIC -WCDTD HTML TransitionalEN> MySQL数据库中SQL语句中 关于日期.时间\时间戳的函数   一 MySQL 获得当 ...

  9. mysql中的日期转换函数(类似oracle中的to_date)

    最近使用mysql开发一个项目,发现没有像之前在用oracle数据中那样有to_date方法.mysql中实现日期格式化的方法为date_to_str('日期字符串','日期格式'),而且mysql中 ...

  10. MYSQL中的日期转换

    MYSQL中的日期转换 网址: http://www.eygle.com/digest/2006/09/mysql_date_convert.html 对于每个类型拥有的值范围以及并且指定日期何时间值 ...

随机推荐

  1. hdoj 3555 Bomb(DFA+dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3555 思路分析:该问题要求求解1—N中的数中含有49的数的个数,可以使用DFA来递推dp公式:详细解释 ...

  2. config.json ajenti

    {    "users": {        "root": {            "configs": {               ...

  3. Linux 内核的编译系统

    Linux  的编译使用 GNU make 工具来检查整个系统的文件和调用 gcc 工具以及脚本完毕编译源码生成 image 等操作.要了解整个编译系统,我们首先要了解 Linux 内核的 Makef ...

  4. js静态方法和实例方法

    js静态方法 function foo(){} // 声明类 foo.method = function(){} // 方法体 使用:foo.method() js实例方法 function foo( ...

  5. Java基础--finalize()方法

    原理: 一旦垃圾回收器准备好释放对象占用的存储空间,将首先调用其finalize()方法,并在下一次垃圾回收动作发生时,才会真正回收对象占用的内存. 用途: 1)释放通过某种创建对象方式以外的方式为对 ...

  6. 南阳师范学院ACM官方博客使用说明

    登录之后跳到如下页面: 点击博客进入如下页面: 这里每个人都有一个专栏,大家可以把自己写得博客放到自己的专栏下,同时也可以查看其他人写的博客,相互交流! 在发表博客的时候,选择个人分类中自己的专栏即可 ...

  7. mysql性能调优与架构设计(一)商业需求与系统架构对性能的影响

    这里我们就拿一个看上去很简单的功能来分析一下. 需求:一个论坛帖子总量的统计附加要求:实时更新 在很多人看来,这个功能非常容易实现,不就是执行一条SELECT COUNT(*)的Query 就可以得到 ...

  8. javascript 学习随笔7

    <head> <title>标题页-学无忧(www.xue51.com)</title> <script language="JavaScript& ...

  9. jQuery $.fn.extend方式自定义插件

    之前例子是扩展jQuery的工具方法,即通过$.xxx(para);的形式来使用的.下面是扩展jquery对象的方法,即任意一个jquery对象都已访问. 具体如下: wyl.js: (functio ...

  10. Python学习之路——函数

    一.Python2.X内置函数表: 注:以上为pyton2.X内置函数,官方网址:https://docs.python.org/2/library/functions.html 二.Python3. ...