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 ...
随机推荐
- 在ASP.NET MVC中对表进行通用的增删改
http://www.cnblogs.com/nuaalfm/archive/2009/11/11/1600811.html 预备知识: 1.了解反射技术 2.了解C#3.0中扩展方法,分布类,Lin ...
- ACM比赛_注意
ACM比赛_注意: 比赛前: 1.前一天早一点睡觉 2.避免参加激烈的活动,以免比赛时精力不足; 3.少喝水,并提前上厕所; 4.把账号,密码都准备好,放在txt中 5.提前创建多个程序(etc.10 ...
- Kubernetes PV/PVC使用实践
转载于https://www.cnblogs.com/ericnie/p/7733281.html pv,pvc的概念不解释了,之前在registry中已经使用过PV和PVC,现在想把WebLog ...
- unity解析json的两种方式
一直比较钟情于json,用来做数据交互,堪称完美!下面简单说一下unity使用C#脚本如何解析json数据吧. 一.写解析类,借助于JsonUtility.FromJson 直接给个例子吧 1.jso ...
- Window10+Python3.5安装opencv
Window10+Python3.5安装opencv 标签: opencvpython 2017-05-14 16:47 2201人阅读 评论(0) 收藏 举报 分类: Python编程(41) ...
- rsync命令的基本使用
rsync命令的基本使用 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. rsync服务软件是一款开源,高速的,数据同步(拷贝)工具. 一.rsync服务的特点 1>.本地拷贝 ...
- 在MySQL或者SQLServer中,添加对象后自动返回主键到对象模型中的配置方式
设置是否使用JDBC的getGenereatedKeys方法获取主键并赋值到keyProperty设置的领域模型属性中.MySQL和SQLServer执行auto-generated key fiel ...
- 科学计算三维可视化---Mlab基础(常用控制函数)
- 设置PyCharm中的Python代码模版
再MacOs运行的PyCharm中,执行python文件,如果不指定python文件字符编码会报错: SyntaxError: Non-ASCII character , but no encodin ...
- CSS3实战之background篇
在CSS3中,background可以添加多个背景图像组,背景图像之间通过逗号进行分隔. 每个背景图像层都可以包含下面的值 background-image 定义背景图像 background-col ...