집 >데이터 베이스 >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은 프로시저 정의에 나타나지 않습니다.
li>위 내용은 MySQL 함수와 프로시저의 가장 중요한 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!