Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

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은 프로시저 정의에 나타나지 않습니다.