今天使用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;;