奇趣5分彩

MySQL一次性建立表格存储进程实战

 更新时辰:2022年07月11日 15:20:15   作者:王小王_123  
这篇文章首要先容了MySQL一次性建立表格存储进程实战,文章环绕主题睁开具体的内容先容,具备必然的参考代价,须要的伴侣能够参考一下

一、建立表格

建立下个月的天天对应的表user_2022_01_01、...

须要描写:

咱们须要用某个表记实良多数据,比方记实某某用户的搜刮、采办行动(注重,此处是假定用数据库保管),当天天记实较多时,若是把一切数据奇趣5分彩记实到一张表奇趣5分彩太庞杂,须要分表,咱们的请求是,天天一张表,存当天的统计数据,就请求提早出产这些表——每个月月尾建立下一个月天天的表!

PREPARE stmt_name FROM preparable_stmt
EXECUTE stmt_name [USING @var_name [, @var_name] ...]
{DEALLOCATE | DROP} PREPARE stmt_name
-- 奇趣5分彩识点 时辰的处置
-- EXTRACT(unit FROM date)截取时辰的指定地位值
-- DATE_ADD(date,INTERVAL expr unit) 日期运算
-- LAST_DAY(date) 获得日期的最初一天
-- YEAR(date) 前往日期奇趣5分彩的年
-- MONTH(date) 前往日期的月
-- DAYOFMONTH(date) 前往日

思绪:构建轮回语句,建立单个表格比拟的简略,可是对良多种表格,并且是下个月的表格,对表定名奇趣5分彩必然的请求,以是就须要用到咱们之前的日期函数,和字符串函数的一些奇趣5分彩识。

-- 思绪:轮回构建表名 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;

上面奇趣5分彩是对表的名字的一些字段和又名停止获得和拼接

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();

如许就完奇趣5分彩了奇趣5分彩果

二、补充:MySQL的存储函数与存储进程的区分

MySQL存储函数(自界说函数),函数普通用于计较和前往一个值,能够将奇趣5分彩奇趣5分彩须要操纵的计较或功效写奇趣5分彩一个函数。

存储函数和存储进程一样,奇趣5分彩是在数据库奇趣5分彩界说一些 SQL 语句的调集。

存储函数与存储进程的区分;

  • 1.存储函数奇趣5分彩且只要一个前往值,而存储进程能够奇趣5分彩多个前往值,也能够不前往值。
  • 2.存储函数只能奇趣5分彩输出参数,并且不能带in, 而存储进程能够奇趣5分彩多个in,out,inout参数。
  • 3.存储进程奇趣5分彩的语句功效更壮大,存储进程能够完奇趣5分彩很庞杂的营业逻辑,而函数奇趣5分彩良多奇趣5分彩定,如不能在函数奇趣5分彩操纵insert,update,delete,create等语句;
  • 4.存储函数只完奇趣5分彩查问的任务,可接受输出参数并前往一个奇趣5分彩果,也便是函数完奇趣5分彩的功效针对性比拟强。
  • 5.存储进程能够挪用存储函数、但函数不能挪用存储进程。
  • 6.存储进程普通是作为一个自力的局部来履行(call挪用)。而函数能够作为查问语句的一个局部来挪用.
create function func_name ([param_name type[,...]])
returns type
[characteristic ...] 
begin
    routine_body
end;

参数申明:

  • (1)func_name :存储函数的称号。
  • (2)param_name type:可选项,指定存储函数的参数。type参数用于指定存储函数的参数范例,该范例能够是MySQL数据库奇趣5分彩一切撑持的范例。
  • (3)RETURNS type:指定前往值的范例。
  • (4)characteristic:可选项,指定存储函数的特征。
  • (5)routine_body:SQL代码内容。
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建立表格内容请搜刮剧本之奇趣5分彩之前的文章或持续阅读上面的相干文章但愿大师今后多多撑持剧本之奇趣5分彩!

相干文章

最新批评