MySQL学习笔记:创建整年日期
见识到另外一种创意,惊讶!
1.创建小数据表 0-9
# 创建小数据表 0-9
DROP TABLE IF EXISTS aa_numbers_small;
CREATE TABLE aa_numbers_small(
number INT);
INSERT INTO aa_numbers_small VALUES(0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
SELECT * FROM aa_numbers_small;
2.创建大数据表 0-10000
# 创建大数据表 0-10000
DROP TABLE IF EXISTS aa_numbers;
CREATE TABLE aa_numbers(number BIGINT);
INSERT INTO aa_numbers
SELECT thousand.number*1000+hundred.number*100+ten.number*10+ones.number
FROM aa_numbers_small thousand, aa_numbers_small hundred, aa_numbers_small ten, aa_numbers_small ones
LIMIT 1000000;
SELECT * FROM aa_numbers;
3.创建时间维表
# 创建时间维表
DROP TABLE IF EXISTS aa_date;
CREATE TABLE aa_date(
date_id BIGINT PRIMARY KEY,
DATE DATE NOT NULL,
DAY CHAR(10),
day_of_week INT,
day_of_month INT,
day_of_year INT,
previous_day DATE NOT NULL DEFAULT '0000-00-00',
next_day DATE NOT NULL DEFAULT '0000-00-00',
weekend CHAR(10) NOT NULL DEFAULT "Weekday",
week_of_year CHAR(2),
MONTH CHAR(10),
month_of_year CHAR(2),
quarter_of_year INT,
YEAR INT,
UNIQUE KEY `date` (`date`)); SELECT * FROM aa_date;
4.填充数据
# 填充数据
INSERT INTO aa_date(date_id, DATE)
SELECT number, DATE_ADD('2018-01-01', INTERVAL number DAY)
FROM aa_numbers
WHERE DATE_ADD('2018-01-01', INTERVAL number DAY) BETWEEN '2018-01-01' AND '2018-12-31'
ORDER BY number;
5.根据日期update其他列数据
# 根据日期update其他列数据
UPDATE aa_date SET
DAY = DATE_FORMAT( DATE, "%W" ),
day_of_week = DAYOFWEEK(DATE),
day_of_month = DATE_FORMAT( DATE, "%d" ),
day_of_year = DATE_FORMAT( DATE, "%j" ),
previous_day = DATE_ADD(DATE, INTERVAL -1 DAY),
next_day = DATE_ADD(DATE, INTERVAL 1 DAY),
weekend = IF( DATE_FORMAT( DATE, "%W" ) IN ('Saturday','Sunday'), 'Weekend', 'Weekday'),
week_of_year = DATE_FORMAT( DATE, "%V" ),
MONTH = DATE_FORMAT( DATE, "%M"),
month_of_year = DATE_FORMAT( DATE, "%m"),
quarter_of_year = QUARTER(DATE),
YEAR = DATE_FORMAT( DATE, "%Y" );
6.日期函数测试
# 测试
SELECT DATE_FORMAT('2018-05-29', '%W'); # Tuesday
SELECT DAYOFWEEK('2018-05-29'); # 3
SELECT DATE_FORMAT('2018-05-29', '%d'); # 29
SELECT DATE_FORMAT('2018-05-29', '%j'); # 149
SELECT DATE_ADD('2018-05-29', INTERVAL -1 DAY); # 2018-05-28
SELECT DATE_SUB('2018-05-29', INTERVAL 1 DAY); # 2018-05-28
SELECT DATE_ADD('2018-05-29', INTERVAL 1 DAY); # 2018-05-30
SELECT IF(DATE_FORMAT('2018-05-26', '%W') IN ('Saturday','Sunday'), 'Weekend', 'Weekday'); # Weekend
SELECT DATE_FORMAT('2018-05-29', '%V'); # 21
SELECT DATE_FORMAT('2018-05-29', '%M'); # May
SELECT DATE_FORMAT('2018-05-29', '%m'); # 05
SELECT QUARTER('2018-05-29') # 2
SELECT DATE_FORMAT('2018-05-29', '%Y');# 2018
END 2018-05-29 14:34:57
MySQL学习笔记:创建整年日期的更多相关文章
- MYSQL学习笔记三:日期和时间函数
MYSQL学习笔记三:日期和时间函数 1. 获取当前日期的函数和获取当前时间的函数 /*获取当前日期的函数和获取当前时间的函数.将日期以'YYYY-MM-DD'或者'YYYYMMDD'格式返回 */ ...
- mysql学习笔记-创建用户以及登录,基本信息查询
第一天: 创建一个mysql账号:create user ‘新的用户名’@‘localhost’identified by ‘口令’: Now()显示当日日期和时间,user()显示当前的用户,ver ...
- MySQL学习笔记八:日期/时间的处理
MySQL日期时间的处理,在其官网文档上都有详细的阐述,想了解更多的同学可自行查阅. 1.查询当前日期时间:函数有now(),localtime(),current_timestamp(),sysda ...
- MySQL学习笔记一
MySQL 学习笔记 一 一.数据库简单介绍 1. 按照数据库的发展时间顺序,主要出现了以下类型数据库系统: Ø 网状型数据库 Ø 层次型数据库 Ø 关系型数据库 Ø 面向对象数据库 上面4中数据库系 ...
- Mysql学习笔记(一)数据类型
原文:Mysql学习笔记(一)数据类型 学习内容: Mysql基本数据类型. 1.数字类型.. i.整型 Mysql数据类型 含义(有符号) tinyint(m ...
- 【mysql学习笔记整理】
/*mysql学习笔记整理*/ /*常用的数据库操作对象*/ #库的操作#创建#数据库的创建USE mysql;CREATE DATABASE db_x;#删除#删除数据库DROP DATABASE ...
- MySql学习笔记四
MySql学习笔记四 5.3.数据类型 数值型 整型 小数 定点数 浮点数 字符型 较短的文本:char, varchar 较长的文本:text, blob(较长的二进制数据) 日期型 原则:所选择类 ...
- 一千行MySQL学习笔记 (转)
出处: 一千行MySQL学习笔记 /* 启动MySQL */ net start mysql /* 连接与断开服务器 */ mysql -h 地址 -P 端口 -u 用户名 -p 密码 /* 跳过权 ...
- mysql basic operation,mysql总结,对mysql经常使用语句的详细总结,MySQL学习笔记
mysql> select * from wifi_data where dev_id like "0023-AABBCCCCBBAA" ; 1.显示数据库列表.show d ...
- Mysql学习笔记(三)对表数据的增删改查。
正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...
随机推荐
- Controller向View传值方式总结
http://www.cnblogs.com/guohu/p/4377974.html 总结发现ASP.NET MVC中Controller向View传值的方式共有6种,分别是: ViewBag Vi ...
- (三)论sizeof与strlen之间的区别
一.sizeof sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组.指针.类型.对象.函数等. 它的功能是:获得保 ...
- 报错laravel/horizon v1.4.3 requires ext-pcntl * -> the requested PHP extension pcntl is missing from your system.的解决办法
执行composer install后报以下错误: Problem 1 - laravel/horizon v1.4.3 requires ext-pcntl * -> the requeste ...
- tp5.1 redis 使用
第一步:在框架根目录config里面新建redis.php文件配置ip及端口:如下: <?php return [ 'host' => '140.143.190.248', 'port' ...
- Docker入门与应用系列(二)镜像管理
1.1 什么是镜像 简单说,Docker镜像是一个不包含Linux内核而又精简的Linux操作系统. 1.2 镜像从哪里来 Docker Hub是由Docker公司负责维护的公共注册中心,包含大量的容 ...
- Hadoop生态圈-hive优化手段-作业和查询优化
Hadoop生态圈-hive优化手段-作业和查询优化 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.
- Centos7远程桌面 vnc/vnc-server的设置
Centos7与Centos6.x有了很大的不同. 为了给一台服务器装上远程桌面,走了不少弯路.写这篇博文,纯粹为了记录,以后如果遇到相同问题,可以追溯. 1.假定你的系统没有安装vnc的任何软件,那 ...
- codevs 3327 选择数字
3327 选择数字 时间限制: 1 s 空间限制: 256000 KB 题目描述 Description 给定一行n个非负整数a[1]..a[n].现在你可以选择其中若干个数,但不能有超过k个连续 ...
- ZeroMQ API(三) 消息
1.初始化消息 1.1 zmq_msg_init(3) 1.1.1 名称 zmq_msg_init - 初始化空的ZMQ消息 1.1.2 概要 int zmq_msg_init(zmq_msg_t * ...
- ECMAScript6语法检查规范错误信息说明
项目中使用ECMAScript6的时候经查会使用语法检查,下面是常见错误信息的汇总: “Missing semicolon.” : “缺少分号.”, “Use the function form of ...