mysql interval 3 day_Mysql之INTERVAL与DATE_SUB与EXTRACT函数的使用

1. INTERVAL

INTERVAL代表的是时间间隔

MySQL中的时间间隔类型有如下几种:

177646711_1_20191210110511829.png

1.1 利用INTERVAL做时间的加减法

示例:

加法:SQL>SELECT DATE '2018-11-01' INTERVAL '10 11' DAY_HOUR;

结果:2018-11-11 11:00:00

减法:SQL> select date '2018-11-11 11:00:00' -INTERVAL '10 11' DAY_HOUR ;

结果:2018-11-01 00:00:00

2. EXTRACT:用于返回日期/时间的单独部分,比如年、月、日、小时、分钟等等

格式:EXTRACT(unit FROM date)

unit取值表:

177646711_2_2019121011051232.png

示例1:

SELECT

EXTRACT(YEAR FROM NOW()) AS years ,

EXTRACT(MONTH FROM NOW()) AS months,

EXTRACT(DAY FROM NOW()) AS days;

结果:

177646711_3_20191210110512407.png

示例2:

SELECT NOW(),EXTRACT(DAY_SECOND FROM NOW());

结果:

177646711_4_20191210110512563.png

3. DATE_SUB:从日期减去指定的时间间隔

DATE_SUB有个相反的函数DATE_ADD(),但因为业务上用DATE_SUB

的情况多,而且DATE_SUB也能实现增加时间间隔的功能,所以我大多用

DATE_SUB.

格式: DATE_SUB(日期, 时间间隔, 时间间隔类型type)

时间间隔即interval函数

间隔类型type可取:

177646711_5_20191210110512813.png

示例1:

SELECT DATE_SUB('2018-11-11 12:00',INTERVAL '0 12' DAY_HOUR);

结果:

177646711_6_20191210110512907.png

示例2:

SELECT DATE_SUB('2018-11-11 12:00',INTERVAL '1 2 3 4' DAY_SECOND);

结果:

177646711_7_201912101105131.png

示例3:

SELECT DATE_SUB('2018-11-11 12:00',INTERVAL '1 2' YEAR_MONTH);

结果:

177646711_8_2019121011051394.png

4 复合函数实现查询上个月月末月初日期

现在3个函数都了解了,怎么实现查询上个月的月初和月末的日期呢?

4.1 上个月月末

1.首先用 函数 查询出来这个月过了几天

select EXTRACT(DAY FROM NOW()) DAY

2.用 DATE_SUB减去这时间间隔

SELECT

DATE_SUB(DATE_FORMAT(NOW(), '%y-%m-%d'),

INTERVAL EXTRACT(DAY FROM NOW()) DAY);

结果:

177646711_9_20191210110513266.png

4.2 上个月月初

1.算出这个月过了几天

select EXTRACT(DAY FROM NOW()) DAY;

写此文的时间为11月7日,这个月过了7天,如果11月7日减去6天的话,就是月

初,所以

select EXTRACT(DAY FROM NOW())-1 DAY;

6天就是距离月初的时间间隔

2.用date_sub得到本月月初时间

SELECT

DATE_SUB(DATE_FORMAT(NOW(), '%y-%m-%d'),

INTERVAL EXTRACT(DAY FROM NOW()) - 1 DAY);

177646711_10_20191210110513360.png

3.继续用date_sub将上述结果,减去一个月

SELECT DATE_SUB(DATE_SUB(DATE_FORMAT(NOW(), '%y-%m-%d'),INTERVAL EXTRACT(DAY FROM NOW()) - 1 DAY),INTERVAL 1 MONTH);

结果:

177646711_11_20191210110513579.png

来源:https://www.icode9.com/content-2-593051.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/277578.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

(二十四)面向对象

class Car {int num;String name;String color;public static void run() {System.out.println("行驶中");} } //再类中定义的变量:成员变量 //在类中定义的函数:成员函数 class Demo1 {public static void main(String[] args) {//创建一个ca…

mysql 三主_MySQL主主复制3

一、创建并授权用户在每一台(主)服务器上创建一个用户,并为之授权,使它们可以互相访问彼此的数据库在Server-1上:创建一个充许Server-2来访问的用户server2,密码为:server2mysql> GRANT REPLICATION SLAVE ON *.*> TO ‘ser…

0727日志

为什么80%的码农都做不了架构师?>>> c端线上地址 http://x.diandanme.com/fe/?d183#/ 什么时候来需求,我做好准备了吗? eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwOlwvXC94LmRpYW5kYW5tZS5jb21cL2FwaVwvd2VjaGF0XC…

Python基础学习总结__Day3

一、集合 1.特性:无序且天生去重,格式为{} 2.作用: (1)去重 (2)关系测试 3.可调用函数(常见对列表操作) (1)取…

day8网络编程,面向对象1

一.只是回顾 1.导入模块的顺序,首先从当前目录下找,再从环境变量里面找,使用"sys.path.insert(0,需要导入的环境变量)"加入需要导入文件的环境变量; 2.如果不同项目中有相同的文件,需要导入文件,需要将非当前项目中右键添加的环境变量取消,将当前的环境变量添加上去;…

mysql练手数据_MySQL新手练习

操作插入数据 的语法 :INSERT INTO 表名称 VALUES(值1,值2,......);修改数据 的语法:UPDATE 表名称 SET 字段名1 值1, 字段名2值2,...... 【WHERE 条件】;删除数据 的语法:delete from 表名 【[where 条件】;delete 表1&#xff…

spring security config

spring secuirty 相关的配置解析 permitAll()与web.ignoring() ingore是完全绕过了spring security的所有filter,相当于不走spring securitypermitall没有绕过spring security,其中包含了登录的以及匿名的。转载于:https://www.cnblogs.com/MND1024/p/10…

TSPITR方式数据库找回误操作丢失的数据

一、TSPITR介绍 TSPITR全称是Tablespace Point In Time Recover(表空间基于时间点的不完全恢复)。原理是通过辅助实例基于时间还原出误操作前的数据通过DataPump将数据导入到目标数据库。TSPITR的最大好处是不需要生产库停机。 二、适用场景 表空间时点恢…

乌班图系统的MySQL_乌班图系统mysql主从备份

一.准备系统:ubuntu 14.04.2 LTSMysql: server version 5.5.43两台主机可以互相通信:192.168.1.11 master192.168.1.12 slave二.步骤Master部分:1.创建备份帐号:slave密码:slaveGrant repl…

mysql table alter_MySQL-ALTER TABLE命令学习[20180503]

学习ALTER TABLE删除、添加和修改字段和类型CREATE TABLE alter_tab01(id int,col01 char(20))enginInnoDB default charsetutf8;删除字段ALTER TABLE DROP ;mysql> alter table alter_tab01 dropcol01;Query OK, 0 rows affected (0.01sec)Records: 0 Duplicates: 0 Warnin…

时间戳转换

13 位时间戳转换 1 通过java,如下: public static String timeStamp2Date(String time) {Long timeLong Long.parseLong(time);SimpleDateFormat sdf new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//要转换的时间格式Date date;try {date …

React.Component(V16.8.6)

组件的生命周期 挂载 当组件实例被创建并插入 DOM 中时,其生命周期调用顺序如下: constructor()static getDerivedStateFromProps()render()componentDidMount()componentWillMount() 之后将废弃 更新 当组件的 props 或 state 发生变化时会触发更新。组…

mysql date类型加一个月jdbc_JDBC操作数据库Date类型数据

JDBC操作数据库Date类型数据由于java原生的工具类java.util提供的Date对象与JDBC提供的Date对象并不相同分别是java.util.Date和java.sql.Datejava.sql.Date是java.util.Date的子类所以在进行增删改查部分操作中,不能直接将原生工具类的Date对象直接运用到JDBC中可以…

使用深度学习TensorFlow框架进行图片识别

Apsara Clouder大数据专项技能认证:使用深度学习TensorFlow框架进行图片识别本认证系统的介绍了深度学习的一些基础知识,以及Tensorflow的工作原理。通过阿里云机器学习PAI基于经典的CIFAR-10数据集实现图片识别。学员可以通过本实验,对深度学…

删除开发分支 新建另一个开发分支

//查看状态 git status //查看分支 会有一个分支git branch -d wlh-dev git branch //删除wlh-dev 分支 git branch -d wlh-dev //再次查看分支 git branch //拉代码 git pull //查看状态 git status //新分支创建的同时切换分支 git checkout -b wlh-dev1222 //…

ES语法及-IK分词器

{"query": {"query_string": {"default_field": "title",//全文搜索"query": "器大"}} } "id":1, "title":"Elasticsearch是一个基于Lucene的搜索服务器", "content":&q…

Git仓库配置

安装git依赖包 yum -y install curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc perl-ExtUtils-MakeMaker 源码安装 wget https://github.com/git/git/archive/v2.7.4.zip unzip v2.7.4.zip cd git-2.7.4 make prefix/usr/local/git all make prefix/usr/l…

python3 tkinter电子书_Python3 Tkinter-Text

1.创建from tkinter import *rootTk()tText(root)t.pack()root.mainloop()2.添加文本from tkinter import *rootTk()tText(root)t.insert(1.0,0123456789)t.insert(1.0,ABDCEFGHIJ)t.pack()root.mainloop()3.设置添加位置from tkinter import *rootTk()tText(root)for i in ran…

问题 1: 区间交集

问题 1: 区间交集 题目描述 输入 5 个正整数 a1、b1、a2、b2 和 c,如果 c 在区间[a1, b1]内 并且 c 也在区间[a2, b2]内,输出”in”,否则输出”out”。 注意:方括号表示的是闭区间,[a, b]是包括 a 和 b 的。 输入 一行…

python倒三角形粉色填充笔的形状海龟_Python001-Turtle(海龟绘图)详解

一、简介Turtle库是Python语言中的一个绘制图像的函数库。详细文档: https://docs.python.org/zh-cn/3/library/turtle.html二、使用1.画布设置(canvas)(1)设置画布大小turtle.screensize(canvwidthNone, canvheightNone, bgNone)参数分别为画布的宽(单位像素), 高,…