时间:2021-07-01 10:21:17 帮助过:23人阅读
存储过程,英文名Stored Procedure,说简单点,就是将MySQL语句集或必要的程序封装在一个结构体里面,存储在数据库中,供外部调用的一个数据库对象,存储过程在思想上很简单,就是SQL代码的封装与重用。
2、学习前准备(主题引出)
创建一张简单表名为table1,仅有一个列name;
SQL语句:create table table1(name varchar(10));
再创建两张表运动员和赛事情况表;
SQL语句-运动员表:
create table Players(
id int(10) Auto_Increment Not null Primary Key,
name varchar(20) Not null,
age varchar(4) not null,
gender varchar(4))Engine=InnoDB Auto_increment=1 Default Charset=utf8;
SQL语句-赛事情况表:
create table Matches(
id int(10) Auto_Increment Not null,
MATCHNO int(5) Not null,
TEAMNO Varchar(6) not Null,
PLAYERNO int(7) Not null ,
WON Int(8) not null,
LOST varchar(2),
Primary Key(id))Engine=InnoDB Auto_increment=1 default Charset =utf8;
向三张表插入数据:
insert into table1 values(78);insert into table1 values(‘ls‘);
insert into players values(1,‘lsq‘,22,‘男‘);insert into Players values(2,‘lqq‘,23,‘女‘);
insert into Matches values(1,5,6,3,8,9); insert into Matches values(2,2,3,4,3,8);
注意:小细节,关于SQL语句结构体是不分大小写的,但表名必须区分大小写,我用的Mysql版本是8.0后的版本。
这些语句我们可以写成存储语句,外部调用,一次性执行。
存储过程语句:
Delimiter //声明语句结束符,可以自定义:
DELIMITER $$
或
DELIMITER //
其他任意符号都行,结构体写完,推荐都用";" 习惯了。
声明存储过程:
CREATE PROCEDURE proc_name(IN p_in int)
存储过程开始和结束符号:
BEGIN .... END
变量定义:
DECLARE num int unsigned default 100;
Declare char_1 varchar(10) default ‘‘;
变量赋值:
set num=23;
set char_1=‘我是齐天大圣‘;
存储过程结构体:
存储过程体包含了在过程调用时必须执行的语句,例如:dml、ddl语句,if-then-else和while-do语句、声明变量的declare语句等
过程体格式:以begin开始,以end结束(可嵌套)
BEGIN
BEGIN
BEGIN
statements;
END
END
END
Delimiter //
Create Procedure proc_in(In p_in varchar(20))
Begin
select p_in;
insert into table1 values(p_in);
select * from table1;
set p_in=‘我是牛魔王‘;
select p_in;
End;
//
Delimiter ;
set @p_in=‘我是齐天大圣‘;
call proc_in(@p_in);
设置传入参数值:
调用存储过程: 可以看到外部参数被传进存储过程体,然后再插入table1表中,接着在结构体内更改了变量。
例2:结构体内部参数传到外面
Delimiter //调用存储过程:可以看出“太白金星”并没有被传到存储过程结构体中。
select @p_out;
结果是结构体中返回的变量“牛魔王”。
例3:既能输入也能输出
只需InOut: create procedure inout_param(InOut p_inout int) 这里不再详细阐释。 4.2、关于存储过程变量 局部声明变量:DECLARE variable_name [,variable_name...] datatype [DEFAULT value];其中,datatype 为 MySQL 的数据类型,如: int, float, date,varchar(length)
例如:
DECLARE l_int int unsigned default 400; DECLARE l_numeric number(8,2) DEFAULT 9.95; DECLARE l_date date DEFAULT ‘1999-12-31‘; DECLARE l_datetime datetime DEFAULT ‘1999-12-31 23:59:59‘; DECLARE l_varchar varchar(255) DEFAULT ‘This will not be padded‘; 变量赋值: SET 变量名 = 表达式值 [,variable_name = expression ...] set x=500; 在存储过程汇总使用变量:CREATE PROCEDURE GreetWorld1() SELECT CONCAT(@greeting,‘ World‘) As "hello world";
SET @greeting=‘Hello‘;
CALL GreetWorld1( );
在MySQL客户端使用存储变量:读者自行测试
SELECT ‘Hello World‘ into @x;
SELECT @x;
SET @y=‘Goodbye Cruel World‘;
SELECT @y;
SET @z=1+2+3;
SELECT @z;
在存储过程间传递全局范围的用户变量:不推荐,滥用变量会导致难以理解和管理
CREATE PROCEDURE p1() SET @last_procedure=‘p1‘;
CREATE PROCEDURE p2() SELECT CONCAT(‘Last procedure was ‘,@last_procedure);
CALL p1( );
CALL p2( );
4.3、存储过程查看
select routine_name from information_schema.routines where routine_schema=‘数据库名‘;
select routine_name from information_schema.routines where routine_schema=‘shop‘;show procedure status where db=‘shop‘;
show create procedure first_proc; #表示查看创建存储过程的语句
4.4、删除存储过程 drop procedure proc_name; 4.5、存储过程修改 注:存储过程只能修改特征,不能修改过程里面的sql语句及参数变量,如果想对过程体结构更改,只能是删掉存储过程,然后重建。 ALTER {PROCEDURE | FUNCTION} sp_name [characteristic ...]存储过程的特征characteristic:指定存储的特性
1、COMMENT ‘string‘是注释信息;
LANGUAGE SQL是指明过程体是用sql语言编写的,而不是java或php;
2、SQL SECURITY { DEFINER | INVOKER }指明谁有权限来执行:
DEFINER表示只有定义者自己才能够执行;
INVOKER表示调用者可以执行。
MySQL之存储过程实例讲解(创建、调用、查看、修改、删除)
标签:dde 一个 lan store inf 插入 删除 primary span