MySQL一次性创建表格存储过程实战 |
一、创建表格创建下个月的每天对应的表user_2022_01_01、... 需求描述: 我们需要用某个表记录很多数据,比如记录某某用户的搜索、购买行为(注意,此处是假设用数据库保存),当每天记录较多时,如果把所有数据都记录到一张表中太庞大,需要分表,我们的要求是,每天一张表,存当天的统计数据,就要求提前生产这些表——每月月底创建下一个月每天的表! PREPARE stmt_name FROM preparable_stmt EXECUTE stmt_name [USING @var_name [, @var_name] ...] {DEALLOCATE | DROP} PREPARE stmt_name -- 知识点 时间的处理 -- EXTRACT(unit FROM date)截取时间的指定位置值 -- DATE_ADD(date,INTERVAL expr unit) 日期运算 -- LAST_DAY(date) 获取日期的最后一天 -- YEAR(date) 返回日期中的年 -- MONTH(date) 返回日期的月 -- DAYOFMONTH(date) 返回日 思路:构建循环语句,创建单个表格比较的简单,但是对于很多种表格,而且是下个月的表格,对于表命名有一定的要求,所以就需要用到我们之前的日期函数,和字符串函数的一些知识 。 -- 思路:循环构建表名 user_2021_11_01 到 user_2020_11_30;并执行create语句 。 use mysql7_procedure; drop procedure if exists proc22_demo; delimiter $$ create procedure proc22_demo() begin declare next_year int; declare next_month int; declare next_month_day int; declare next_month_str char(2); declare next_month_day_str char(2); -- 处理每天的表名 declare table_name_str char(10); declare t_index int default 1; -- declare create_table_sql varchar(200); 首先利用declare 定义需要的一些变量,next_year(下一年),next_month(下一个月),next_month_day(天数),这里为什么要这样去定义,特别是年,月,不应该是提前知道的吗?答案是有时候比如是12月呢,那么下一个月的年份就不一样了,所以需要利用日期函数的一些运算去解决这些问题 。 -- 获取下个月的年份 set next_year = year(date_add(now(),INTERVAL 1 month)); -- 获取下个月是几月 set next_month = month(date_add(now(),INTERVAL 1 month)); -- 下个月最后一天是几号 set next_month_day = dayofmonth(LAST_DAY(date_add(now(),INTERVAL 1 month))); if next_month < 10 then set next_month_str = concat('0',next_month); else set next_month_str = concat('',next_month); end if; while t_index <= next_month_day do if (t_index < 10) then set next_month_day_str = concat('0',t_index); else set next_month_day_str = concat('',t_index); end if; 上面都是对表的名字的一些字段和别名进行获取和拼接 set table_name_str = concat(next_year,'_',next_month_str,'_',next_month_day_str); -- 拼接create sql语句 set @create_table_sql = concat( 'create table user_', table_name_str, '(`uid` INT ,`ename` varchar(50) ,`information` varchar(50)) COLLATE='utf8_general_ci' ENGINE=InnoDB'); -- FROM后面不能使用局部变量! prepare create_table_stmt FROM @create_table_sql; execute create_table_stmt; DEALLOCATE prepare create_table_stmt; set t_index = t_index + 1; end while; end $$ delimiter ; call proc22_demo(); 这样就实现了效果 二、补充:MySQL的存储函数与存储过程的区别MySQL存储函数(自定义函数),函数一般用于计算和返回一个值,可以将经常需要使用的计算或功能写成一个函数 。 存储函数和存储过程一样,都是在数据库中定义一些 SQL 语句的集合 。 存储函数与存储过程的区别;
create function func_name ([param_name type[,...]]) returns type [characteristic ...]? begin ? ? routine_body end; 参数说明:
create database mydb9_function; -- 导入测试数据 use mydb9_function; set global log_bin_trust_function_creators=TRUE; -- 信任子程序的创建者 -- 创建存储函数-没有输输入参数 drop function if exists myfunc1_emp; delimiter $$ create function myfunc1_emp() returns int begin ? declare cnt int default 0; ? ? select count(*) into ?cnt from emp; ? return cnt; end $$ delimiter ; -- 调用存储函数 select myfunc1_emp(); create database mydb9_function; -- 导入测试数据 use mydb9_function; set global log_bin_trust_function_creators=TRUE; -- 信任子程序的创建者 -- 创建存储函数-没有输输入参数 drop function if exists myfunc1_emp; delimiter $$ create function myfunc1_emp() returns int begin ? declare cnt int default 0; ? ? select count(*) into ?cnt from emp; ? return cnt; end $$ delimiter ; -- 调用存储函数 select myfunc1_emp(); 到此这篇关于MySQL一次性创建表格存储过程实战的文章就介绍到这了,更多相关MySQL创建表格内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持! |