Mysql錯誤集

來源:互聯網
上載者:User

今天使用Mysql寫函數,遇到了不少問題,現在將遇到的問題,和解決方案寫下來.

第一:mysql中,每一行都需要加一個分號, - -!

第二:在mysql的函數中, 不能返回結果集.所以不能使用select * from tablename ,select column_name from tablename 等方式.否則要報錯not allowed to return aresult  set from a function.此時改成 Select xx into 方式即可..

第三:錯誤提示:"This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary"

  應該是我們開啟了bin-log, 我們就必須指定我們的函數是否是 
   1 DETERMINISTIC 不確定的 
   2 NO SQL 沒有SQl語句,當然也不會修改資料 
   3 READS SQL DATA 只是讀取資料,當然也不會修改資料 
   4 MODIFIES SQL DATA 要修改資料 
   5 CONTAINS SQL 包含了SQL語句 

 其中在function裡面,只有 DETERMINISTIC, NO SQL 和 READS SQL DATA 被支援。 如果我們開啟了 bin-log, 我們就必須為我們的function指定一個參數。 

我們可以通過設定如下的參數來關掉這個。 

SET GLOBAL log_bin_trust_function_creators = 1; 

最後完成的代碼如下:

代碼

CREATE DEFINER = CURRENT_USER FUNCTION `func_get_city_name`(`cid` int)
RETURNS varchar(50)
BEGIN
DECLARE result varchar(50);
SET result = '' ;
SELECT region_name INTO result FROM vsvt_region WHERE region_id = cid;
RETURN result;
END;;

 

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.