MySQL学习记录--操作时间数据

1、返回日期的时间函数

  date_add() : 可以为指定日期增加/减少任意一段时间间隔。下面举例将当前日期增加一个月和减少一个月

mysql> select date_add(current_date(), interval 1 month) as add_one_month;
+---------------+
| add_one_month |
+---------------+
| 2016-12-30    |
+---------------+
1 row in set (0.00 sec)

mysql> select date_add(current_date(), interval -1 month) as reduce_one_month;
+------------------+
| reduce_one_month |
+------------------+
| 2016-10-30       |
+------------------+
1 row in set (0.00 sec)

  格式:date_add(‘要修改的时间‘,interval 数量 时间间隔类型), 下面展示一些常见的时间间隔类型

间隔名称 描述
Second 秒数
Minute 分钟数
Hour 小时数
Day 天数
Month 月份
Year 年份
Minute_second 分钟和秒,以":"分隔
Hour_second 小时、分钟和秒,以":"分隔
Year_month 年份和月份,以"-"分隔

  下面对时间间隔后三种举例:

  ①、将当前时间增加3小时20分钟

mysql> select current_timestamp;  -- 当前时间
+---------------------+
| current_timestamp   |
+---------------------+
| 2016-11-30 15:22:46 |
+---------------------+
1 row in set (0.00 sec)

mysql> select date_add(current_timestamp, interval ‘3:20:00‘ Hour_second) as add_HourSecond;
+---------------------+
| add_HourSecond      |
+---------------------+
| 2016-11-30 18:42:49 |
+---------------------+
1 row in set (0.00 sec)

  ②、将日期‘2000-01-01‘增加16年10个月

mysql> select date_add(‘2000-01-01‘, interval ‘16-10‘ Year_month) as add_Year_month;
+----------------+
| add_Year_month |
+----------------+
| 2016-11-01     |
+----------------+
1 row in set (0.00 sec)

  

函数last_day() : 返回所求月份的最后一天

  举例:求"2016-01-01"该月的最后一天

mysql> select last_day(‘2016-01-01‘);
+------------------------+
| last_day(‘2016-01-01‘) |
+------------------------+
| 2016-01-31             |
+------------------------+
1 row in set (0.00 sec)

 无论提供的参数是date型还是datetime型,last_day()函数都将返回一个date值

2、返回字符串的时间函数

  dayname() : 返回所求的日期是星期几

  举例:求当前日期是星期几

mysql> select dayname(current_date);
+-----------------------+
| dayname(current_date) |
+-----------------------+
| Wednesday             |
+-----------------------+
1 row in set (0.00 sec)

  year()、month()、day()、time()...提取部分时间

mysql> select year(current_date),month(current_date),day(current_date),time(current_timestamp);
+--------------------+---------------------+-------------------+-------------------------+
| year(current_date) | month(current_date) | day(current_date) | time(current_timestamp) |
+--------------------+---------------------+-------------------+-------------------------+
|               2016 |                  11 |                30 | 16:12:57                |
+--------------------+---------------------+-------------------+-------------------------+
1 row in set (0.00 sec)

3、返回数字的时间函数

  datediff() : 计算两个日期相隔的天数

  举例:计算"2000-01-01"距离现在有多少天

mysql> select datediff(‘2016-11-30‘, ‘2000-01-01‘);
+--------------------------------------+
| datediff(‘2016-11-30‘, ‘2000-01-01‘) |
+--------------------------------------+
|                                 6178 |
+--------------------------------------+
1 row in set (0.00 sec)

  注:datediff()函数会忽略参数中的时钟值。

    sql server 同样具备datediff()函数,但可以在指定时间间隔的类型(如年、月、日、小时等)。sql server 实现上一个例子的方法:

select datediff(day, ‘2016-11-30‘, ‘2000-01-01‘);
时间: 2024-10-01 08:03:21

MySQL学习记录--操作时间数据的相关文章

mysql学习笔记——对数据表中记录的操作

对记录的操作,主要有增.删.改.查 一.记录插入命令:insert into 表名(列名,列名, .... ) values(值, 值, ....); 值个数应该列个数相同,值顺序和列顺序相同,值类型和列字段类型匹配 当表名后面省略列名时,values后面要给出所有列的值 插入数据时,字符串添加 单引号 '' ---- 字符型和日期型数据应包含在单引号中 插入数据时,中文乱码问题:将客户端的编码集设置为gbk 修改mysql 配置文件,永久改变客户端编码集 ----- mysql/my.ini

mysql学习笔记——对数据记录查询操作的补充(单表内查询)

select ... from ... where ... group by ... having ... order by ... limit...; (顺序固定) 1.select 指定所要检索的字段(列) select 后加distinct关键字,则可去除重复的记录,其中,重复的记录是指 所有字段值都相同的记录 2.from 指定查询数据表,可以是表名,也可以是别名 通常是在一个表达式不易读取时,对其取别名: 表达式 as 别名; 3.where 前置过滤条件 --- 将表数据过滤掉一部分

Mysql --学习:大量数据快速导入导出

声明:此文供学习使用,原文:https://blog.csdn.net/xiaobaismiley/article/details/41015783 [实验背景] 项目中需要对数据库中一张表进行重新设计,主要是之前未分区,考虑到数据量大了以后要设计成分区表,同时要对数据库中其他表做好备份恢复的工作. [实验环境] Mysql版本:mysql-5.6.19 操作系统:Ubuntu 12.04 内存:32G CPU:24核  Intel(R) Xeon(R) CPU E5-2620 0 @ 2.00

mysql 学习记录(二十五)--mysql日志

一.理论: 1.错误日志: a.记录了mysqld启动和停止时以及出错时的相关信息,当数据库出现故障导致无法启动时可以先查看此信息. b.可用--log-error来指定mysqld保存错误日志文件的位置 2.二进制日志: a.statement:记录的都是语句.优点:日志记录清晰易读.日志量少.对I/O影响较小,缺点:在某些情况下slave的日志复制会出错 b.row:将每一行的变更记录到日志中,而不是记录sql语句.优点:记录每一行的数据变化细节,不会出现某些情况下无法复制的情况,缺点:日志

MySQL学习记录一

1.MySQL join操作 left join以左表为基础,其记录会全部表示出来,而右表只显示满足搜索条件的记录.right join以右表为基础,其记录会全部显示出来,而左表只显示满足搜索条件的记录.下面先创建两个表进行测试,表a包含ID(aID)以及姓名(aName),表b包含ID(bID)以及学号(bNum). 图1 从上图可以看出,表格创建成功并插入了几条数据.下面开始测试左连接.右连接,结果如图2所示. 图2 从图2可以看出,左连接时,以表a为基础,共5条记录.结果中,表b只显示a.

MySQL学习记录

前提:数据库:books里面有table:customersorders 选择数据库use books 查询所有表格show tables查询单个表格select × from orders查询表格的数据类型show create table orders 修改数据类型alter table orders modify id vaechar(20) 增加两行数据insert into orders values('','','',''),('','','','')增加特定位置的数据insert

Mysql 学习记录

( xampp 的mysql 与 直接用 dnf 安装的 mysql 有冲突! ) 1. 数据库基本知识: 一张表的行 又称为 记录 一张表的列 又称为 字段 表结构:所有字段,规定了你的每一条记录所应该填的内容,不能随意乱写 2.mysql 登录: mysql -u root -p password (root密码) (待继续更新)

MySQL学习记录--分组与聚集

一.group by 子句 group by 字句可对数据进行分组. 以MySQL5.5的sakila数据库中的film数据表举例:查找出各个电影等级的电影总数 mysql>SELECT rating, COUNT(*) AS ratingCount FROM film > GROUP BY rating 结果如下: 可以看出,group by 子句对其后接的字段进行了分组,而这里也用了聚集函数count()对各分组中的项目数进行统计. 二.聚集函数 由上例可以知道,聚集函数是对某个分组的所有

mysql学习之旅-数据迁移-备份-恢复

1.数据迁移 将/tmp/t3.txt中的数据导入到t3表中,数据以逗号为分割符 load data infile ‘/tmp/t3.txt’ into table t3 fields terminated by ','; 将table2表中的数据导出为文件data.txt,以逗号为分隔符 SELECT * INTO OUTFILE 'data.txt' ->     FIELDS TERMINATED BY ',' ->     FROM table2; #####在mysql命令行内执行