> 데이터 베이스 > MySQL 튜토리얼 > mysql 저장 프로시저 변수

mysql 저장 프로시저 변수

WBOY
풀어 주다: 2023-05-08 18:45:37
원래의
1473명이 탐색했습니다.

MySQL은 통신 및 쿼리에 SQL 언어를 사용하는 동시에 저장 프로시저 및 변수를 지원하는 인기 있는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 이 기사에서는 MySQL 저장 프로시저 및 변수의 개념과 이를 생성하고 사용하는 방법을 소개합니다.

MySQL 저장 프로시저

저장 프로시저는 MySQL에 저장하고 재사용할 수 있는 SQL 문의 모음입니다. 특정 작업을 자동화하여 데이터베이스 처리 효율성을 높일 수 있습니다. 저장 프로시저는 반복 작업을 완료하고, 코드를 단순화하고, 성능을 개선하고, 복잡한 작업을 재사용 가능한 더 작은 구성 요소로 줄이는 데 사용되는 경우가 많습니다. 저장 프로시저는 여러 SQL 문을 함께 패키지하여 여러 SQL 문을 단일 단계에서 처리할 수도 있습니다.

저장 프로시저는 일반적으로 다음과 같은 상황에서 사용됩니다.

  • 반복 작업: 동일한 SQL 문 집합을 반복적으로 실행해야 하는 경우 매번 입력할 필요가 없습니다. 이러한 SQL 문은 호출되는 곳 어디에서나 실행할 수 있는 저장 프로시저로 패키지됩니다.
  • 프로그램 모듈화: 저장 프로시저를 사용하면 복잡한 SQL 문을 모듈식 구성 요소로 나눌 수 있습니다. 이렇게 하면 프로그램의 논리와 실행 방법을 더 잘 볼 수 있습니다.
  • 데이터 보호: 저장 프로시저는 더 강력한 보안을 유지하면서 데이터 액세스 및 수정을 수행할 수 있습니다. 이는 사용자가 중요한 데이터에 대해 특정 작업을 수행하는 것을 방지합니다.
  • 비즈니스 규칙 도입: 저장 프로시저는 데이터베이스에 비즈니스 규칙을 포함할 수 있으므로 시스템에서 비즈니스 규칙의 분산을 줄일 수 있습니다.

저장 프로시저는 변수처럼 데이터베이스에 저장할 수 있으며 MySQL 명령줄, PHP, Java, .NET 등을 포함한 모든 MySQL 클라이언트에서 사용할 수 있습니다.

MySQL 저장 프로시저 생성

MySQL 저장 프로시저 생성에는 다음과 같은 특정 구문 규칙이 필요합니다. 다음은 저장 프로시저를 생성하기 위한 템플릿입니다.

CREATE PROCEDURE procedure_name
(
    [IN | OUT | INOUT] parameter_name parameter_type
    [, [IN | OUT | INOUT] parameter_name parameter_type]...
)
BEGIN
    -- 存储过程体
    SQL语句;
    执行的任务;
END
로그인 후 복사

그 중 CREATE PROCEDURE는 저장 프로시저의 선언이고, procedure_name은 저장 프로시저의 이름이며, parameter_name은 저장 프로시저의 매개변수 이름이고, parameter_type은 저장 프로시저의 매개변수 유형으로 정수, 문자열, 날짜 등이 될 수 있습니다. BEGINEND는 저장 프로시저 본문의 시작과 끝을 표시합니다. 나머지 SQL 문과 실행 작업은 저장 프로시저 본문 내에서 수행됩니다. CREATE PROCEDURE是存储过程的声明,procedure_name是存储过程的名称,parameter_name是存储过程的参数名称,parameter_type是存储过程的参数类型,可以是整数、字符串、日期等。 BEGINEND标记了存储过程体的开始和结束。其余SQL语句和执行任务是在存储过程体内进行的。

下面是一个例子,创建一个简单的MySQL存储过程,用于查询一个员工的名字和工资:

CREATE PROCEDURE SHOW_EMPLOYEE(IN employee_id INT)
BEGIN
    SELECT name, salary
    FROM employees
    WHERE id = employee_id;
END
로그인 후 복사

在上述示例代码中,首先创建了一个名为SHOW_EMPLOYEE的存储过程,其中传递的参数是一个名为employee_idIN型整数。然后存储过程体内执行了一个SQL查询,在employees表中查找指定ID的员工名字和工资。

使用MySQL存储过程

一旦存储过程被创建,就可以通过调用它来使用它。存储过程可以用CALL语句来调用,也可以在MySQL的客户端工具中使用。下面是一个简单的调用MySQL存储过程SHOW_EMPLOYEE的例子:

CALL SHOW_EMPLOYEE(3);
로그인 후 복사

在上述示例代码中,调用存储过程SHOW_EMPLOYEE,并传递了一个参数3。存储过程将返回ID为3的员工的名字和工资。

MySQL变量

MySQL变量是存储数据的一种方法,它们允许在执行存储过程和查询时创建并存储数据。变量可以存储各种类型的数据,包括整数、字符串、日期等。

MySQL变量使用以下语法进行声明:

DECLARE variable_name variable_type [DEFAULT default_value]
로그인 후 복사

其中,DECLARE是声明变量的关键字,variable_name是变量名称,variable_type是变量类型,default_value是可选的,是变量的默认值。变量可以在存储过程或查询中使用,也可以被其他变量引用。

下面是一个MySQL变量的示例,它用于计算两个整数相加:

DECLARE a INT DEFAULT 5;
DECLARE b INT DEFAULT 3;
DECLARE c INT;

SET c = a + b;
SELECT c;
로그인 후 복사

在上述示例代码中,声明了三个变量abca的默认值为5,b的默认值为3,c没有默认值。然后在代码中将c赋值为ab之和,最后将c

다음은 직원의 이름과 급여를 쿼리하는 간단한 MySQL 저장 프로시저를 생성하는 예입니다.

rrreee

위의 예제 코드에서 SHOW_EMPLOYEE라는 저장소가 먼저 생성됩니다. 전달된 매개변수는 employee_id라는 이름의 IN 유형의 정수입니다. 그런 다음 저장 프로시저 본문은 SQL 쿼리를 실행하여 employees 테이블에서 지정된 ID를 가진 직원의 이름과 급여를 찾습니다.

MySQL 저장 프로시저 사용🎜🎜 저장 프로시저가 생성되면 이를 호출하여 사용할 수 있습니다. 저장 프로시저는 CALL 문을 사용하여 호출하거나 MySQL 클라이언트 도구에서 사용할 수 있습니다. 다음은 MySQL 저장 프로시저 SHOW_EMPLOYEE를 호출하는 간단한 예입니다. 🎜rrreee🎜위의 예 코드에서는 저장 프로시저 SHOW_EMPLOYEE가 호출되고 매개변수 3이 전달됩니다. 저장 프로시저는 ID가 3인 직원의 이름과 급여를 반환합니다. 🎜🎜MySQL 변수🎜🎜MySQL 변수는 데이터를 저장하는 방법으로, 저장 프로시저 및 쿼리를 실행하는 동안 데이터를 생성하고 저장할 수 있습니다. 변수는 정수, 문자열, 날짜 등 다양한 유형의 데이터를 저장할 수 있습니다. 🎜🎜MySQL 변수는 다음 구문을 사용하여 선언됩니다. 🎜rrreee🎜여기서, DECLARE는 변수를 선언하는 키워드이고, variable_name은 변수 이름, variable_type는 변수 유형이고, <code>default_value는 선택 사항이며 변수의 기본값입니다. 변수는 저장 프로시저나 쿼리에서 사용될 수 있으며 다른 변수에서 참조될 수도 있습니다. 🎜🎜다음은 두 정수의 덧셈을 계산하는 데 사용되는 MySQL 변수의 예입니다. 🎜rrreee🎜위 예제 코드에서 세 개의 변수 a, b은 > 및 c로 선언되며 a의 기본값은 5, b의 기본값은 3, c에는 기본값이 없습니다. 그런 다음 코드의 <code>ab의 합에 c를 할당하고 마지막으로 c를 출력합니다. 🎜🎜결론🎜🎜MySQL 저장 프로시저와 변수는 개발자가 작업을 보다 효율적으로 완료하는 동시에 데이터베이스 처리 성능을 향상시키는 데 도움이 됩니다. 개발자는 저장 프로시저와 변수를 사용하여 데이터베이스 작업을 보다 모듈화하고 더 강력한 비즈니스 규칙과 보안을 구현할 수 있습니다. 실제 개발 작업에서 개발자는 코드 가독성과 유지 관리 가능성을 보장하기 위해 항상 MySQL 저장 프로시저 및 변수의 모범 사례에 주의를 기울여야 합니다. 🎜

위 내용은 mysql 저장 프로시저 변수의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿