mysql存储过程实战基础入门



/**
-- 1.什么是存储过程?
存储过程是存储在数据库服务器中的一组sql语句,通过在查询中调用一个指定的名称来执行这些sql语句命令。


-- 2.为什么要使用mysql存储过程?
我们都知道应用程序分为两种,一种是基于web,一种是基于桌面,他们都和数据库进行交互来完成数据的存取工作。
假设现在有一种应用程序包含了这两 种,现在要修改其中的一个查询sql语句,那么我们可能要同时修改他们中对应
的查询sql语句,当我们的应用程序很庞大很复杂的时候问题就出现这,不易维 护!另外把sql查询语句放在我们的web
程序或桌面中很容易遭到sql注入的破坏。而存储过程程正好可以帮我们解决这些问题。


-- 3.存储过程(stored procedure)、存储例程(store routine)、存储函数区别
Mysql存储例程实际包含了存储过程和存储函数,它们被统称为存储例程。
其中存储过程主要完成在获取记录或插入记录或更新记录或删除记录,即完成select insert delete update等的工作。
而存储函数只完成查询的工作,可接受输入参数并返回一个结果。


创建mysql存储过程、存储函数
create procedure 存储过程名(参数)
存储过程体
create function 存储函数名(参数)


下面是存储过程的例子:
mysql> DELIMITER // 
mysql> CREATE PROCEDURE proc1(OUT s int) 
   -> BEGIN
   -> SELECT COUNT(*) INTO s FROM user; 
   -> END
   -> // 
mysql> DELIMITER ;


注:
(1)这里需要注意的是DELIMITER//和DELIMITER;两句,DELIMITER是分割符的意思,因为MySQL默认以";"为分隔符,
     如果我们没有声明分割符,那么编译器会把存储过程当成SQL语句进行处理,则存储过程的编译过程会报错,所以要
     事先用DELIMITER关键字申明当 前段分隔符,这样MySQL才会将";"当做存储过程中的代码,不会执行这些代码,用完
     了之后要把分隔符还原。
(2)存储过程根据需要可能会有输入、输出、输入输出参数,这里有一个输出参数s,类型是int型,如果有多个参数用","分割开。
(3)过程体的开始与结束使用BEGIN与END进行标识。


关于参数的语法说明:
   MySQL存储过程的参数用在存储过程的定义,共有三种参数类型,IN,OUT,INOUT,形式如:
   CREATE  PROCEDURE 存储过程名([[IN |OUT |INOUT ] 参数名 数据类形...])
   【1】IN      输入参数:表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值
   【2】OUT     输出参数:该值可在存储过程内部被改变,并可返回
   【3】INOUT   输入输出参数:调用时指定,并且可被改变和返回
*/
-- 创建一个空表格
CREATE TABLE test(
id INT(11) NULL
)
SELECT * FROM test;


# 1.创建一个IN参数的存储过程

DELIMITER //  
CREATE PROCEDURE demo_in_parameter(IN p_in INT)
BEGIN
SELECT p_in;
SET p_in=2;
SELECT p_in;
END
// 

DELIMITER ;


/*执行结果:*/
SET @p_in=4;
CALL demo_in_parameter(@p_in);
SELECT @p_in;




# 2.创建一个OUT参数的存储过程
DELIMITER //
CREATE PROCEDURE demo_out_parameter(OUT p_out INT)
BEGIN
 SELECT p_out;
 SET p_out=2;
 SELECT p_out;
END
//
DELIMITER;
SET @p_out=3;
CALL demo_out_parameter(@p_out);
SELECT @p_out;


# 3.创建一个INOUT参数的例子
DELIMITER //
CREATE PROCEDURE demo_inout_parameter(INOUT p_inout INT)
BEGIN
 SELECT p_inout;
 SET p_inout=7;
 SELECT p_inout;
END
//
DELIMITER;


/*执行结果*/
SET @p_inout=5;
CALL demo_inout_parameter(@p_inout);


/*查看某个存储过程的详细信息*/
SHOW CREATE PROCEDURE demo_inout_parameter;


# 查看当前数据库中所有的存储过程的状态
SHOW PROCEDURE STATUS;


# 删除某个存储过程

DROP PROCEDURE sp_demo_in_parameter;
DROP PROCEDURE sp;
DROP PROCEDURE sp2;
DROP PROCEDURE proce2;







猜你喜欢

转载自blog.csdn.net/sunny1015627/article/details/78552475