DELIMITER $$ DROP FUNCTION IF EXISTS genPerson$$ CREATE FUNCTION genPerson(name varchar(20)) RETURNS varchar(50) BEGIN DECLARE str VARCHAR(50) DEFAULT ''; SET @tableName=name; SET str=CONCAT('create table ', @tableName,'(id int, name varchar(20));'); return str; END $$ DELIMITER ;
위 그림의 sql에 관한 한
(1) DELIMITER $$는 종결자를 정의합니다. MySQL의 기본 종결자는 세미콜론이지만 함수 본문에서는 세미콜론을 사용할 수도 있습니다. 충돌을 방지하려면 추가 종료자를 정의해야 합니다.
(2) 존재하는 경우 함수 삭제 genPerson$$ genPerson 함수가 이미 존재하는 경우 삭제합니다.
(3) CREATE FUNCTION은 genPerson 함수를 생성합니다. 함수의 매개 변수는 name이고 반환 값은 varchar(50)입니다.
(4) 함수 본문은 BEGIN과 END 사이에 위치합니다.
(5) DECLARE는 변수를 선언하고 str 유형은 varchar(50)이며 기본값은 비어 있습니다.
(6) CONCAT은 여러 문자열을 연결합니다.
(7) RETURN은 연결된 문자열 str을 반환합니다.
실행 결과에서 알 수 있습니다
mysql에서 함수 생성, 오류 코드: 1418
해결 방법1. 생성 기능이 켜져 있는지 확인하세요이 함수에는 DETERMINISTIC, NO SQL, 또는 READS SQL DATA 선언 및 바이너리 로깅이 활성화되어 있습니다( 덜 안전한 log_bin_trust_function_creators 변수를 *사용하고 싶을 수도 있습니다). 이는 생성 함수 기능이 활성화되지 않음을 의미합니다.
show variables like '%func%'; ------------------------------------------- +---------------------------------+-------+ | Variable_name | Value | +---------------------------------+-------+ | log_bin_trust_function_creators | OFF | +---------------------------------+-------
SET GLOBAL log_bin_trust_function_creators = 1;3.
위 내용은 MySQL에서 함수를 만드는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!