mysql的内建日期处理函数

下面的表格列出了MySQL 中最重要的内建日期函数:

函数 描述
NOW() 返回当前的日期和时间
CURDATE() 返回当前的日期
CURTIME() 返回当前的时间
DATE() 提取日期或日期/时间表达式的日期部分
EXTRACT() 返回日期/时间按的单独部分
DATE_ADD() 给日期添加指定的时间间隔
DATE_SUB() 从日期减去指定的时间间隔
DATEDIFF() 返回两个日期之间的天数
DATE_FORMAT() 用不同的格式显示日期/时间

时间差函数(TIMESTAMPDIFF、DATEDIFF)

需要用MySQL计算时间差,使用TIMESTAMPDIFF、DATEDIFF,记录一下实验结果

--0
select datediff(now(), now());

--2
select datediff(‘2015-04-22 23:59:00‘, ‘2015-04-20 00:00:00‘);

--2
select datediff(‘2015-04-22 00:00:00‘, ‘2015-04-20 23:59:00‘);

--1
select TIMESTAMPDIFF(DAY, ‘2015-04-20 23:59:00‘, ‘2015-04-22 00:00:00‘);

--2
select TIMESTAMPDIFF(DAY, ‘2015-04-20 00:00:00‘, ‘2015-04-22 00:00:00‘);

--2
select TIMESTAMPDIFF(DAY, ‘2015-04-20 00:00:00‘, ‘2015-04-22 12:00:00‘);

--2
select TIMESTAMPDIFF(DAY, ‘2015-04-20 00:00:00‘, ‘2015-04-22 23:59:00‘);

--71
select TIMESTAMPDIFF(HOUR, ‘2015-04-20 00:00:00‘, ‘2015-04-22 23:00:00‘);

--4260
select TIMESTAMPDIFF(MINUTE, ‘2015-04-20 00:00:00‘, ‘2015-04-22 23:00:00‘);

日期转换计算函数(date_add、day、date_format、str_to_date)

-- 用日期与字符串转换,计算当月第一天、下月第一天
select curdate() as ‘当前日期‘,
DATE_FORMAT(curdate(), ‘%Y-%m‘) as ‘当前月份‘,
str_to_date(concat(DATE_FORMAT(curdate(), ‘%Y-%m‘), ‘-01‘), ‘%Y-%m-%d‘) as ‘当前月的第一天‘,
date_add(str_to_date(concat(DATE_FORMAT(curdate(), ‘%Y-%m‘), ‘-01‘), ‘%Y-%m-%d‘), interval 1 month) as ‘下月的第一天‘;

-- 当前月的最后一天
select last_day(curdate());

-- 下月第一天
select date_add(last_day(curdate()), interval 1 day);

-- 当天为当月的第几天
select day(curdate());

-- 当月第一天
select date_add(curdate(), interval 1-(day(curdate())) day);

原文地址:https://www.cnblogs.com/shamo89/p/8685935.html

时间: 2024-11-07 21:03:35

mysql的内建日期处理函数的相关文章

Hive 内建操作符与函数开发——深入浅出学Hive

第一部分:关系运算 Hive支持的关系运算符 ?常见的关系运算符 ?等值比较: = ?不等值比较: <> ?小于比较: < ?小于等于比较: <= ?大于比较: > ?大于等于比较: >= ?空值判断: IS NULL ?非空判断: IS NOT NULL ?LIKE比较: LIKE ?JAVA的LIKE操作: RLIKE ?REGEXP操作: REGEXP ?等值比较: = 语法:A=B 操作类型:所有基本类型 描述: 如果表达式A与表达式B相等,则为TRUE:否则为

mysql与oracle的日期/时间函数小结

前言 本文的日期/时间全部格式化为”2016-01-01 01:01:01“形式: MONITOR_TIME为数据库表字段: 字符串与日期/时间相互转换函数 Oracle 日期/时间转字符串函数:to_char(t.MONITOR_TIME, 'yyyy-mm-dd hh24:mi:ss') as monitorTime 字符串转日期/时间函数:TO_Date(”2016-01-01 01:01:01“, 'yyyy-mm-dd hh24:mi:ss') Mysql 日期/时间转字符串函数:DA

Python 内建的filter()函数用于过滤序列。

例如,在一个list中,删掉偶数,只保留奇数,可以这么写: def is_odd(n): return n % 2 == 1 list(filter(is_odd, [1, 2, 4, 5, 6, 9, 10, 15])) # 结果: [1, 5, 9, 15](返回False就过滤掉) 习题:回数是指从左向右读和从右向左读都是一样的数,例如12321,909.请利用filter()滤掉非回数: # -*- coding: utf-8 -*-from functools import reduc

mysql内建指令下常用选项参数

在使用mysql的过程中常常应为种种原因,平时要对mysql的备份.优化等等操作写脚本以方便管理.如果要写脚本,那就必须使用到mysql的内建指令的选项参数,这里就简要的说几个比较常用的选项参数: -h, --host=name        设置连接的主机 -u, --user=name        指定使用的用户名 -p, --password[=name]    输入密码 -P, --port=#          指定使用的端口 -A,  --no-auto-rehash      不

MySQL日期时间函数大全(转)

MySQL日期时间函数大全 DAYOFWEEK(date)  返回日期date是星期几(1=星期天,2=星期一,……7=星期六,ODBC标准)mysql> select DAYOFWEEK('1998-02-03');  -> 3 WEEKDAY(date)  返回日期date是星期几(0=星期一,1=星期二,……6= 星期天). mysql> select WEEKDAY('1997-10-04 22:23:00');  -> 5 mysql> select WEEKDAY

Mysql研究之MySQL常用内置函数完全解析

说明: 1)可以用在SELECT/UPDATE/DELETE中,及where,orderby,having中 2)在函数里将字段名作为参数,变量的值就是字段所对应的每一行的值. 3)在程序设计语言如C++中提供的函数,MySQL大部分也提供了,关于MySQL函数的完整信息,请参阅<MySQL参考手册> 一.字符串函数[比较常用,需要掌握] 1. concat(s1,s2,…,sn) #把传入的参数连接成一个字符串 selectconcat(‘abc’,’def’); selectconcat(

MYSQL常用内置函数详解说明

函数中可以将字段名当作变量来用,变量的值就是该列对应的所有值:在整理98在线字典数据时(http://zidian.98zw.com/),有这要一个需求,想从多音字duoyinzi字段值提取第一个拼音作为拼音pinyin字段的值,如:duoyinzi(ā,á,ǎ,à,a),想提取ā作为pinyin的值:数据有好几万条,不想用程序一条条处理,只想用一个sql来实现,后来了解了下MYSQL常用内置函数,是可以做到的:sql:UPDATE ol_zidian set pinyin=LEFT(duoyi

mysql日期时间函数2

win7可以设定每周从哪一天开始,win2003等不能方便的修改.有的是周日开始,有的是周一开始.而工作中有的时候每周是从周六开始算的,有些数据需要按周统计,那么那种方式比较好呢? 通过下面的研究,认为yearweek()是适合的,它返回的是 201311这样的格式.若要把周六当做新的一周的开始,那么就是: select yearweek(DATE_ADD(now(), INTERVAL 1 DAY)); mysql> select yearweek(DATE_ADD(now(), INTERV

【转】MySQL日期时间函数大全

MySQL日期时间函数大全 1.DAYOFWEEK(date)  返回日期date是星期几(1=星期天,2=星期一,……7=星期六,ODBC标准)mysql> select DAYOFWEEK('1998-02-03');  -> 3 2.WEEKDAY(date)  返回日期date是星期几(0=星期一,1=星期二,……6= 星期天). mysql> select WEEKDAY('1997-10-04 22:23:00');  -> 5 mysql> select WEE