> 데이터 베이스 > MySQL 튜토리얼 > MySQL 함수와 프로시저의 가장 중요한 차이점은 무엇입니까?

MySQL 함수와 프로시저의 가장 중요한 차이점은 무엇입니까?

WBOY
풀어 주다: 2023-09-17 22:49:02
앞으로
1293명이 탐색했습니다.

MySQL 函数和过程之间最显着的区别是什么?

프로시저와 함수의 가장 중요한 차이점은 서로 다른 목적으로 호출된다는 점입니다. 그 외에도 프로시저와 함수의 차이점은 다음과 같습니다.

  • 프로세스는 값을 반환하지 않습니다. 대신 테이블 수정이나 검색된 레코드 처리 등의 작업을 수행하기 위해 CALL 문을 사용하여 호출됩니다.

    반면에 함수는 표현식 내에서 호출되며 표현식에 사용할 단일 값을 호출자에게 직접 반환합니다. 즉, 함수는 상수, 내장 함수 또는 테이블 열에 대한 참조와 동일한 방식으로 표현식에서 사용될 수 있습니다.

  • CALL 문을 사용하여 함수를 호출할 수 없습니다. 표현식 내에서는 프로시저를 호출할 수 없습니다.

  • 루틴 생성 구문은 다음과 같이 프로시저 및 함수와 다소 다릅니다. -

CREATE
   [DEFINER = { user | CURRENT_USER }]
   PROCEDURE sp_name ([proc_parameter[,...]])
   [characteristic ...] routine_body

CREATE
   [DEFINER = { user | CURRENT_USER }]
   FUNCTION sp_name ([func_parameter[,...]])
   RETURNS type
   [characteristic ...] routine_body

proc_parameter:
   [ IN | OUT | INOUT ] param_name type

func_parameter:
   param_name type

type:
   Any valid MySQL data type

characteristic:
   COMMENT 'string'
   | LANGUAGE SQL
   | [NOT] DETERMINISTIC
   | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
   | SQL SECURITY { DEFINER | INVOKER }

routine_body:
   Valid SQL routine statement
로그인 후 복사
  • 프로시저 매개변수는 입력 전용, 출력 전용 또는 입력과 출력 모두로 정의할 수 있습니다. 이는 프로시저가 출력 매개변수를 사용하여 호출자에게 값을 다시 전달할 수 있음을 의미합니다. 이 값은 CALL 문 다음의 문에서 액세스할 수 있습니다.

    반면에 함수에는 입력 매개변수만 있습니다. 따라서 프로시저와 함수 모두 매개변수를 가질 수 있지만 프로시저의 매개변수 선언 구문은 함수의 매개변수 선언 구문과 다릅니다.

  • 함수는 값을 반환하므로 함수 정의에 반환 값의 데이터 유형을 나타내는 RETURNS 절이 있어야 합니다. 또한 호출자에게 값을 반환하려면 함수 본문 내에 RETURN 문이 하나 이상 있어야 합니다.

    한편, RETURNS 및 RETURN은 프로시저 정의에 나타나지 않습니다.

    li>

위 내용은 MySQL 함수와 프로시저의 가장 중요한 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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