> 데이터 베이스 > MySQL 튜토리얼 > MySQL에서 함수를 만드는 방법

MySQL에서 함수를 만드는 방법

WBOY
풀어 주다: 2023-05-30 10:34:05
앞으로
3533명이 탐색했습니다.

    Mysql에서 함수 만드는 방법

    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에서 함수를 만드는 방법

    실행 결과에서 알 수 있습니다

    MySQL에서 함수를 만드는 방법

    Mysql에서 함수 오류 코드 1418을 생성할 수 없습니다

    mysql에서 함수 생성, 오류 코드: 1418

    이 함수에는 DETERMINISTIC, NO SQL, 또는 READS SQL DATA 선언 및 바이너리 로깅이 활성화되어 있습니다( 덜 안전한 log_bin_trust_function_creators 변수를 *사용하고 싶을 수도 있습니다). 이는 생성 함수 기능이 활성화되지 않음을 의미합니다.

    해결 방법

    1. 생성 기능이 켜져 있는지 확인하세요

    show variables like '%func%';
    -------------------------------------------
    +---------------------------------+-------+
    | Variable_name                   | Value |
    +---------------------------------+-------+
    | log_bin_trust_function_creators | OFF   |
    +---------------------------------+-------
    로그인 후 복사

    2. 켜세요

    SET GLOBAL log_bin_trust_function_creators = 1;
    로그인 후 복사
    3.

    위 내용은 MySQL에서 함수를 만드는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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