中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL創建函數時報錯'ERROR 1336 (0A000): Dynamic SQL'怎么辦

發布時間:2021-11-06 15:35:39 來源:億速云 閱讀:1146 作者:小新 欄目:MySQL數據庫

這篇文章主要介紹MySQL創建函數時報錯'ERROR 1336 (0A000): Dynamic SQL'怎么辦,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

創建函數時報錯
mysql> delimiter $$
mysql> CREATE FUNCTION is_SQLScriptReferenceExist (THE_REFERENCE VARCHAR(75), THE_VERSION_LEVEL_TABLE_NAME VARCHAR(75)) RETURNS INTEGER DETERMINISTIC
    ->     BEGIN
    ->     DECLARE THE_REFERENCE_LABEL VARCHAR(80);
    ->     DECLARE CONTINUE HANDLER FOR NOT FOUND
    ->     BEGIN
    ->     RETURN 0;
    ->     END;
    ->         SELECT concat('select c_reference_label INTO THE_REFERENCE_LABEL from ', THE_VERSION_LEVEL_TABLE_NAME, ' where C_REFERENCE_LABEL = ''', THE_REFERENCE, '''') INTO @stmt;
    ->         PREPARE STMT FROM @stmt;
    ->         EXECUTE STMT;
    ->         /* select c_reference_label into THE_REFERENCE_LABEL from THE_VERSION_LEVEL_TABLE_NAME where C_REFERENCE_LABEL = THE_REFERENCE; */
    ->         RETURN 1;
    ->     END$$
ERROR 1336 (0A000): Dynamic SQL is not allowed in stored function or trigger
mysql> delimiter ;

報錯原因:
MySQL函數和觸發器中不允許使用動態函數

可以改寫成存儲過程
mysql> delimiter $$
mysql> CREATE PROCEDURE is_SQLScriptReferenceExist (IN THE_REFERENCE VARCHAR(75), IN THE_VERSION_LEVEL_TABLE_NAME VARCHAR(75), OUT V_RET INT(2))
    ->     BEGIN
    ->     DECLARE THE_REFERENCE_LABEL VARCHAR(80);
    ->     DECLARE CONTINUE HANDLER FOR NOT FOUND
    ->     BEGIN
    ->     SET V_RET = 0;
    ->     END;
    ->         SELECT concat('select c_reference_label INTO THE_REFERENCE_LABEL from ', THE_VERSION_LEVEL_TABLE_NAME, ' where C_REFERENCE_LABEL = ''', THE_REFERENCE, '''') INTO @stmt;
    ->         PREPARE STMT FROM @stmt;
    ->         EXECUTE STMT;
    ->         /* select c_reference_label into THE_REFERENCE_LABEL from THE_VERSION_LEVEL_TABLE_NAME where C_REFERENCE_LABEL = THE_REFERENCE; */
    ->         SET V_RET = 1;
    ->     END$$
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter ;

以上是“MySQL創建函數時報錯'ERROR 1336 (0A000): Dynamic SQL'怎么辦”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东山县| 屯昌县| 丹棱县| 新昌县| 泾川县| 三江| 桦甸市| 象州县| 昭觉县| 刚察县| 新河县| 巴彦县| 北票市| 乌拉特前旗| 康定县| 天峻县| 开江县| 鄄城县| 巴东县| 古交市| 百色市| 沙洋县| 阿巴嘎旗| 马关县| 资阳市| 开封市| 迭部县| 肇东市| 津南区| 衡阳县| 宕昌县| 慈溪市| 堆龙德庆县| 仪征市| 正镶白旗| 金寨县| 汉沽区| 临汾市| 土默特右旗| 普陀区| 子长县|