mysql 按照月份自动创建表,以年和月为表明,动态生成。
需求:mysql5.5 数据库,想要根据月份自动创建表,每个月创建一张表,需要数据库自动创建,并根据当前年和月动态生成表名称。
解决办法:1 连接数据库工具为Navicat
2 首先创建存储过程,然后通过创建定时事件执行存储过程。
3 先查看事件是否开启 show variables like '%scheduler%';
4 如果未开启则需要开启 set global event_scheduler = 1;
创建存储过程:
点击查询--》新建查询--> 输入以下代码,然后在函数中就可以查看到建立的存储过程。
2 我这里利用循环一次建立了12张表,以年和月开头为表明。
3 PARTITION BY HASH(GTID) PARTITIONS 100 利用哈希表的形式把每个表分为100个区,提高检索效率
- BEGIN
- declare i int;
- set i=;
- while i< do
- set @sql_create_table_gpstrail = concat(
- 'CREATE TABLE IF NOT EXISTS xj_dt_gpstrail', date_format(date_add(curdate(), interval i month),'%Y%m'),
- "(
- `GTID` int() NOT NULL AUTO_INCREMENT,
- `DeviceId` varchar() DEFAULT NULL COMMENT '设备ID',
- `Longitude` decimal(,) DEFAULT NULL COMMENT '经度',
- `Latitude` decimal(,) DEFAULT NULL COMMENT '纬度',
- `Speed` int() DEFAULT NULL COMMENT '速度',
- `LocationTime` datetime DEFAULT NULL COMMENT '定位时间',
- `ReciveTime` datetime DEFAULT NULL COMMENT '接收时间',
- `loginid` int() DEFAULT NULL COMMENT '登陆人账号',
- `BdLon` decimal(,) DEFAULT NULL COMMENT '百度经度',
- `BdLat` decimal(,) DEFAULT NULL COMMENT '百度纬度',
- PRIMARY KEY (`GTID`)
- ) ENGINE=InnoDB AUTO_INCREMENT= DEFAULT CHARSET=utf8 COMMENT='GPS轨迹'
- PARTITION BY HASH(GTID)
- PARTITIONS
- ");
- PREPARE sql_create_table_gpstrail FROM @sql_create_table_gpstrail;
- EXECUTE sql_create_table_gpstrail;
- set i=i+;
- end while;
- END
创建执行存储过程的事件:
1 打开创建的数据库,点击事件按钮,点击新建事件。
2 在 定义 栏里面输入 CALL sql_create_table_gpstrail(),下面的状态选择ENABLE
3 在计划栏里面配置如图:表示每一年执行一次,开始时间是 2017-02-01 01:00:00
4 保存计划就建立完毕,效果如图:建立了12张gpstrail表 根据年和月份。
创建事件也可不按照上面操作,执行sql语句即可:查询中--》新建查询--》执行
- CREATE EVENT EVENT_pro_sql_create_table_gpstrail
- ON SCHEDULE EVERY QUARTER STARTS DATE_ADD(DATE_ADD(DATE_SUB(CURDATE(),INTERVAL DAY(CURDATE())- DAY), INTERVAL MONTH),INTERVAL HOUR)
- ON COMPLETION PRESERVE ENABLE DO
- CALL sql_create_table_gpstrail(); ;
mysql 按照月份自动创建表,以年和月为表明,动态生成。的更多相关文章
- Hibernate连接mysql数据库并自动创建表
天才第一步,雀氏纸尿裤,Hibernate第一步,连接数据库. Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个 ...
- 支持MySql的数据库自动分表工具DBShardTools发布
支持MySql的数据库自动分表工具DBShardTools发布 前段时间参与了公司的一个项目,这个项目的特点是数据量.访问量都比较大,考虑使用数据库水平分表策略,Google了大半天,竟然没有找到分表 ...
- Hibernate 自动创建表bug问题解决
我在hibernate.cfg.xml配置文件中添加了自动创建表的的属性:(这样当数据库中没有此表是,hibernate就会自动帮我们创建一张表) <property name="hb ...
- Hibernate自动创建表
只要在hibernate.cfg.xml添加这句话,就可以自动生成数据表 <property name="hibernate.hbm2ddl.auto">update& ...
- Hibernate根据实体类自动创建表
Hibernate支持自动建表,在开发阶段很方便,可以保证hbm与数据库表结构的自动同步. 如何使用呢?很简单,只要在hibernate.cfg.xml里加上如下代码 Xml代码<propert ...
- hibernate自动创建表报表不存在
在hibernate.cfg.xml配置了<property name="hibernate.hbm2ddl.auto">update</property> ...
- sql自动创建表并复制数据
---------------自动创建表并复制数据sql,需要自己设置主键----------- select * into 新表 from 旧表
- SQL Server ->> 自动创建表并从文件加载数据
这个存储过程自动创建表并从文件加载数据. 有一点需要说明的是Excel 12.0驱动是兼容了Excel 97-2003和Excel 2007两者格式的Excel文件. CREATE PROCEDURE ...
- Hibrenate实现根据实体类自动创建表或添加字段
Hibernate支持自动建表,在开发阶段很方便,可以保证hbm与数据库表结构的自动同步. 实现: 在配置hibernate的配置文件中将hbm2ddl.auto设置为update,如:Xml代码&l ...
随机推荐
- 记录一个chrome 65渲染的bug
前段时间发现一个chrome 65+的BUG(chrome已更新到66,BUG仍然存在),一个元素同时使用了以下样式(失去焦点和css3的Z轴平移0deg),渲染异常 /*bug style*/ fi ...
- webpack打包之有依赖js模块
一.入口文件main.js var isd = require('./depend.js'); if(isd.isDepend){ console.log('有依赖模块'); } else { con ...
- vue中的组件
一.自定义组件1.组件命名 A.dom模板在HTML模板中始终使用kebab-case命名组件 <kebab-cased-component> </kebab-cased-com ...
- MacOs brew 命令行安装常见工具
brew类似ubuntu系统下的apt-get的功能 安装方法: 在Mac中打开Termal: 输入命令: ruby -e "$(curl -fsSL https://raw.githu ...
- C#选择文件、选择文件夹、打开文件
1.选择文件用OpenDialog OpenFileDialog dialog = new OpenFileDialog(); dialog.Multiselect = true;//该值确定是否可以 ...
- SSM项目搭建
1.新建包 com.javen.controller com.javen.service com.javen.dao com.javen.domain com.javen.mapper 2.log4j ...
- Java笔记(六)列表和队列
列表和队列 一)ArrayList 1.基本原理 ArrayList是一个泛型容器.内部会有一个数组elementData,一般会有预留空间 有一个整数记录实际的元素个数. private trans ...
- python基础一 ------利用生成器生成一个可迭代对象
#利用生成器生成一个可迭代对象#需求:生成可迭代对象,输出指定范围内的素数,利用生成器产生一个可迭代对象#生成器:本身是可迭代的,只是 yield 好比return返回,yield返回后函数冻结状态, ...
- CY7C68013 USB接口相机开发记录 - 第一天:资料下载
一直觉得从头开发一套东西出来会极大的提升自己的自信心,能够最大化的开发自己的潜能.所以在犹豫很久之后决定学习下CY7C68013 USB接口相机的开发. 通过在网上查找多份资料后,觉得工欲善其事必先利 ...
- [P2996][USACO10NOV]拜访奶牛Visiting Cows (树形DP)
之前写在洛谷,结果没保存,作废…… 听说考前写题解RP++哦 思路 很容易想到是 树形DP 如果树形DP不知道是什么的话推荐百度一下 我在这里用vector储存边 设状态f[i][0]为i点不访问,f ...