mysql에서 저장 프로시저와 저장 함수는 데이터베이스에 정의된 SQL 문의 모음입니다. 그 중 저장 함수는 return 문을 통해 함수 값을 반환할 수 있으며 주로 값을 계산하고 반환하는 데 사용되는 반면, 저장 프로시저는 값을 직접 반환하지 않으며 주로 작업을 수행하는 데 사용됩니다.
(추천 튜토리얼: mysql 비디오 튜토리얼)
Stored Procedure in mysql
저장 프로시저를 작성하는 것은 간단한 문제가 아니지만, 저장 프로시저를 사용하면 작업을 단순화하고 중복성을 줄일 수 있습니다. 시간이 지나면 작업 중 오류도 줄어들고 효율성도 향상될 수 있으므로 저장 프로시저를 최대한 활용하는 방법을 배워야 합니다.
다음에서는 주로 저장 프로시저를 생성하는 방법을 소개합니다.
CREATE PROCEDURE 문을 사용하여 저장 프로시저를 생성할 수 있습니다. 구문 형식은 다음과 같습니다.
CREATE PROCEDURE <过程名> ( [过程参数[,…] ] ) <过程体>
[프로시저 매개 변수 [,…] ] 형식
[ IN | OUT | INOUT ] <参数名> <类型>
구문 설명은 다음과 같습니다.
1) 프로시저 이름
현재 데이터베이스에 기본적으로 생성되는 저장 프로시저의 이름입니다. 특정 데이터베이스에 저장 프로시저를 생성해야 하는 경우 이름 앞에 데이터베이스 이름(db_name.sp_name)을 추가하세요.
이름은 MySQL 내장 함수와 동일한 이름을 선택하지 않도록 해야 합니다. 그렇지 않으면 오류가 발생합니다.
2) 프로세스 매개변수
는 프로세스의 매개변수 목록을 저장합니다. 그 중
MySQL 저장 프로시저는 각각 세 가지 키워드 IN, OUT 및 INOUT으로 식별되는 세 가지 유형의 매개변수, 즉 입력 매개변수, 출력 매개변수 및 입력/출력 매개변수를 지원합니다. 그 중 입력 매개변수는 저장 프로시저에 전달될 수 있고, 출력 매개변수는 저장 프로시저가 연산 결과를 반환해야 할 때 사용되며, 입/출력 매개변수는 입력 매개변수와 출력 매개변수로 모두 사용될 수 있다.
매개변수 이름은 데이터 테이블의 열 이름과 동일하면 안 됩니다. 그렇지 않으면 오류 메시지가 반환되지 않더라도 저장 프로시저의 SQL 문은 매개 변수 이름을 열 이름으로 처리합니다. , 예측할 수 없는 결과를 초래합니다.
3) 프로시저 본문
저장 프로시저 본문이라고도 하는 저장 프로시저의 주요 부분에는 프로시저 호출 시 실행되어야 하는 SQL 문이 포함되어 있습니다. 이 섹션은 BEGIN 키워드로 시작하고 END 키워드로 끝납니다. 저장 프로시저 본문에 SQL 문이 하나만 있는 경우 BEGIN-END 플래그를 생략할 수 있습니다.
저장 프로시저를 생성할 때 매우 중요한 MySQL 명령, 즉 DELIMITER 명령이 자주 사용됩니다. 특히 명령줄을 통해 MySQL 데이터베이스를 작동하는 사용자의 경우 이 명령을 사용하는 방법을 배워야 합니다.
MySQL에서는 서버가 SQL 문을 처리할 때 기본적으로 세미콜론이 문의 끝 표시로 사용됩니다. 그러나 저장 프로시저를 생성할 때 저장 프로시저 본문에 여러 SQL 문이 포함될 수 있습니다. 이러한 SQL 문이 여전히 세미콜론을 문 종결자로 사용하는 경우 MySQL 서버는 처리 중에 발견되는 첫 번째 SQL 문으로 끝납니다. 전체 프로그램의 종료자를 삭제하고 더 이상 저장 프로시저 본문의 후속 SQL 문을 처리하지 않습니다.
위 문제를 해결하려면 일반적으로 DELIMITER 명령을 사용하여 종료 명령을 다른 문자로 수정합니다. 구문 형식은 다음과 같습니다.
DELIMITER $$
구문 설명은 다음과 같습니다.
$$는 사용자 정의 종결자입니다. 일반적으로 이 기호는 두 개의 "?"와 같은 특수 기호일 수 있습니다. 두 "엔"기다립니다.
DELIMITER 명령을 사용할 때 백슬래시 "" 문자는 MySQL 이스케이프 문자이므로 사용을 피해야 합니다.
MySQL 명령줄 클라이언트에 다음 SQL 문을 입력합니다.
mysql > DELIMITER ??
이 SQL 문을 성공적으로 실행한 후에는 모든 명령, 문 또는 프로그램의 끝 표시가 두 개의 물음표 "??"로 대체됩니다.
끝 표시를 기본 세미콜론 ";"으로 다시 변경하려면 MySQL 명령줄 클라이언트에 다음 명령문을 입력하세요.
mysql > DELIMITER ;
참고: DELIMITER와 세미콜론 ";" 사이에 공백이 있어야 합니다. 저장 프로시저를 생성하려면 CREATE ROUTINE 권한이 있어야 합니다.
mysql의 저장 함수
MySQL에서는 CREATE FUNCTION 문을 사용하여 저장 함수를 생성합니다. 구문은 다음과 같습니다.
CREATE FUNCTION sp_name ([func_parameter[...]]) RETURNS type [characteristic ...] routine_body
여기서:
sp_name 매개변수: 저장된 이름을 나타냅니다. 함수
func_parameter: 저장된 함수의 매개변수 목록을 나타냅니다.
RETURNS 유형: 반환 값의 유형을 지정합니다.
특성 매개변수: 저장된 함수의 값을 지정합니다. 매개변수는 저장 프로시저와 동일합니다.
routine_body 매개변수: BEGIN...END를 사용하여 SQL 코드의 시작과 끝을 표시할 수 있습니다.
注意:在具体创建函数时,函数名不能与已经存在的函数名重名。除了上述要求外,推荐函数名命名(标识符)为 function_xxx 或者 func_xxx。
func_parameter 可以由多个参数组成,其中每个参数由参数名称和参数类型组成,其形式如下: [IN | OUT | INOUT] param_name type;
其中:
IN 表示输入参数,OUT 表示输出参数,INOUT 表示既可以输入也可以输出;
param_name 参数是存储函数的参数名称;
type 参数指定存储函数的参数类型,该类型可以是 MySQL 数据库的任意数据类型。
例 1
使用 CREATE FUNCTION 创建查询 tb_student 表中某个学生姓名的函数,SQL 语句和执行过程如下:
mysql> USE test; Database changed mysql> DELIMITER // mysql> CREATE FUNCTION func_student(id INT(11)) -> RETURNS VARCHAR(20) -> COMMENT '查询某个学生的姓名' -> BEGIN -> RETURN(SELECT name FROM tb_student WHERE tb_student.id = id); -> END // Query OK, 0 rows affected (0.10 sec) mysql> DELIMITER ;
上述代码中,创建了 func_student 函数,该函数拥有一个类型为 INT(11) 的参数 id,返回值为 VARCHAR(20) 类型。SELECT 语句从 tb_student 表中查询 id 字段值等于所传入参数 id 值的记录,同时返回该条记录的 name 字段值。
创建函数与创建存储过程一样,需要通过命令 DELIMITER // 将 SQL 语句的结束符由“;”修改为“//”,最后通过命令 DELIMITER ; 将结束符号修改成 SQL 语句中默认的结束符号。
如果在存储函数中的 RETURN 语句返回一个类型不同于函数的 RETURNS 子句中指定类型的值,返回值将被强制为恰当的类型。比如,如果一个函数返回一个 ENUM 或 SET 值,但是 RETURN 语句返回一个整数,对于 SET 成员集的相应的 ENUM 成员,从函数返回的值是字符串。
拓展阅读
由于存储函数和存储过程的查看、修改、删除等操作几乎相同,所以我们不再详细讲解如何操作存储函数了。
查看存储函数的语法如下:
SHOW FUNCTION STATUS LIKE 存储函数名; SHOW CREATE FUNCTION 存储函数名; SELECT * FROM information_schema.Routines WHERE ROUTINE_NAME=存储函数名;
可以发现,操作存储函数和操作存储过程不同的是将 PROCEDURE 替换成了 FUNCTION。同样,修改存储函数的语法如下:
ALTER FUNCTION 存储函数名 [ 特征 ... ]
存储函数的特征与存储过程的基本一样。
위 내용은 mysql의 저장 프로시저와 저장 함수란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!