MySQL存储过程---基础

Posted hopeless-dream

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL存储过程---基础相关的知识,希望对你有一定的参考价值。

存储过程

语法

DELIMITER $$

CREATE PROCEDURE `employees`.`a`(参数列表)

    BEGIN
    sql1;
    sql2;
    ...
END$$ DELIMITER ;

语法说明

DELIMITER $$:定义语句结束标记,存储过程体中,每条SQL都使用“;”结束,所有语句作为一个过程体执行,如果过程体中只有一条SQL语句,可以省略begin和end

参数列表:参数模式 参数名 参数类型
参数模式 :
  IN : 输入参数,单独传参。
  OUT : 输出参数,作为返回值的参数。
  INOUT: 既输入有输出,可做输入也可做输出。

调用存储过程

CALL 存储过程名(实参列表)

实例

创建空参数的存储过程

DELIMITER $$

USE `world`$$

DROP PROCEDURE IF EXISTS `t1`$$

CREATE DEFINER=`root`@`10.0.0.%` PROCEDURE `t1`()
BEGIN
SELECT COUNT(*) FROM world.city;
END$$

DELIMITER ;

 

 

 调用

CALL t1()

创建带out参数的存储过程

DELIMITER $$

CREATE
    /*[DEFINER = { user | CURRENT_USER }]*/
    PROCEDURE `world`.`t2`( IN num INT,OUT num1 INT)
    /*LANGUAGE SQL
    | [NOT] DETERMINISTIC
    | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
    | SQL SECURITY { DEFINER | INVOKER }
    | COMMENT ‘string‘*/
    BEGIN
    INSERT INTO t2 VALUES(num);
    SELECT COUNT(*) INTO num1 FROM t2;
    SELECT num1;
    END$$

DELIMITER ;

调用

SET @n2:=0;
CALL t2(2,@n2)
SELECT * FROM t2;

带inout参数的存储过程

DELIMITER $$

CREATE
    /*[DEFINER = { user | CURRENT_USER }]*/
    PROCEDURE `world`.`t3`( INOUT a INT, INOUT b INT, OUT c INT)
    /*LANGUAGE SQL
    | [NOT] DETERMINISTIC
    | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
    | SQL SECURITY { DEFINER | INVOKER }
    | COMMENT ‘string‘*/
    BEGIN
    SELECT a*2 INTO a;
    SELECT b*2 INTO b;
    SELECT a+b INTO c;
    SELECT a,b,c;
    END$$

DELIMITER ;

调用

SET @a:=5;
SET @b:=10;
SET @c:=0;
CALL t3(@a,@b,@c)

 

以上是关于MySQL存储过程---基础的主要内容,如果未能解决你的问题,请参考以下文章

16-mysql基础-mysql中的存储过程

16-mysql基础-mysql中的存储过程

MySQL基础_存储过程与函数

MySQL_基础_存储过程和函数

MySql触发器使用

ava基础MySQL存储过程 Java基础 JDBC连接MySQL数据库