MySQL 錯(cuò)誤1418 的原因分析及解決方法

MySQL開(kāi)啟bin-log后隔显,調(diào)用存儲(chǔ)過(guò)程或者函數(shù)以及觸發(fā)器時(shí),會(huì)出現(xiàn)錯(cuò)誤號(hào)為1418的錯(cuò)誤:

ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO

SQL,or READS SQL DATA in its declaration and binary logging is

enabled(you *might* want to use the less safe

log_bin_trust_function_creators variable)

原因分析:

因?yàn)镃REATE PROCEDURE, CREATE FUNCTION, ALTER PROCEDURE,ALTER

FUNCTION,CALL, DROP PROCEDURE, DROP

FUNCTION等語(yǔ)句都會(huì)被寫(xiě)進(jìn)二進(jìn)制日志,然后在從服務(wù)器上執(zhí)行饵逐。但是括眠,一個(gè)執(zhí)行更新的不確定子程序(存儲(chǔ)過(guò)程、函數(shù)倍权、觸發(fā)器)是不可重復(fù)的掷豺,在從服務(wù)器上執(zhí)行(相對(duì)與主服務(wù)器是重復(fù)執(zhí)行)可能會(huì)造成恢復(fù)的數(shù)據(jù)與原始數(shù)據(jù)不同,從服務(wù)器不同于主服務(wù)器的情況薄声。

為了解決這個(gè)問(wèn)題当船,MySQL強(qiáng)制要求:

在主服務(wù)器上,除非子程序被聲明為確定性的或者不更改數(shù)據(jù)默辨,否則創(chuàng)建或者替換子程序?qū)⒈痪芙^德频。

這意味著當(dāng)創(chuàng)建一個(gè)子程序的時(shí)候,必須要么聲明它是確定性的缩幸,要么它不改變數(shù)據(jù)壹置。

聲明方式有兩種,

第一種:聲明是否是確定性的

DETERMINISTIC和NOT DETERMINISTIC指出一個(gè)子程序是否對(duì)給定的輸入總是產(chǎn)生同樣的結(jié)果竞思。

如果沒(méi)有給定任一特征,默認(rèn)是NOT DETERMINISTIC钞护,所以必須明確指定DETERMINISTIC來(lái)聲明一個(gè)子程序是確定性的盖喷。

這里要說(shuō)明的是:使用NOW() 函數(shù)(或它的同義)或者RAND() 函數(shù)不會(huì)使一個(gè)子程序變成非確定性的。對(duì)NOW()而言难咕,二進(jìn)制日志包括時(shí)間戳并會(huì)被正確的執(zhí)行课梳。RAND()只要在一個(gè)子程序內(nèi)被調(diào)用一次也可以被正確的復(fù)制。所以余佃,可以認(rèn)為時(shí)間戳和隨機(jī)數(shù)種子是子程序的確定性輸入惦界,它們?cè)谥鞣?wù)器和從服務(wù)器上是一樣的。

第二種:聲明是否會(huì)改變數(shù)據(jù)

CONTAINS SQL, NO SQL, READS SQL DATA, MODIFIES SQL用來(lái)指出子程序是讀還是寫(xiě)數(shù)據(jù)的咙冗。

無(wú)論NO SQL還是READS SQL DATA都指出,子程序沒(méi)有改變數(shù)據(jù)漂彤,但是必須明確地指定其中一個(gè)雾消,因?yàn)槿绻魏沃付ǎJ(rèn)的指定是CONTAINS SQL挫望。

默認(rèn)情況下立润,如果允許CREATE PROCEDURE 或CREATE FUNCTION 語(yǔ)句被接受,就必須明確地指定DETERMINISTIC 或 NO SQL與READS SQL DATA 中的一個(gè)媳板,否則就會(huì)產(chǎn)生1418錯(cuò)誤桑腮。

解決方法:

解決辦法也有兩種,

第一種是在創(chuàng)建子程序(存儲(chǔ)過(guò)程蛉幸、函數(shù)破讨、觸發(fā)器)時(shí),聲明為DETERMINISTIC或NO SQL與READS SQL DATA中的一個(gè)奕纫,(我在navicat for mysql的函數(shù)里的高級(jí)的數(shù)據(jù)訪問(wèn)里選擇了NO SQL或READS SQL DATA

例如:

CREATE DEFINER = CURRENT_USER PROCEDURE `NewProc`()

DETERMINISTIC

BEGIN

#Routine body goes here...

END;;

第二種是信任子程序的創(chuàng)建者提陶,禁止創(chuàng)建、修改子程序時(shí)對(duì)SUPER權(quán)限的要求匹层,設(shè)置log_bin_trust_routine_creators全局系統(tǒng)變量為1隙笆。設(shè)置方法有三種:

1.在客戶端上執(zhí)行SET GLOBAL log_bin_trust_function_creators = 1;

2.MySQL啟動(dòng)時(shí),加上--log-bin-trust-function-creators選賢升筏,參數(shù)設(shè)置為1

3.在MySQL配置文件my.ini或my.cnf中的[mysqld]段上加log-bin-trust-function-creators=1

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末撑柔,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子您访,更是在濱河造成了極大的恐慌铅忿,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,865評(píng)論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件洋只,死亡現(xiàn)場(chǎng)離奇詭異辆沦,居然都是意外死亡昼捍,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,296評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)肢扯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)妒茬,“玉大人,你說(shuō)我怎么就攤上這事蔚晨≌ё辏” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,631評(píng)論 0 364
  • 文/不壞的土叔 我叫張陵铭腕,是天一觀的道長(zhǎng)银择。 經(jīng)常有香客問(wèn)我,道長(zhǎng)累舷,這世上最難降的妖魔是什么浩考? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,199評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮被盈,結(jié)果婚禮上析孽,老公的妹妹穿的比我還像新娘。我一直安慰自己只怎,他們只是感情好袜瞬,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,196評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著身堡,像睡著了一般邓尤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上贴谎,一...
    開(kāi)封第一講書(shū)人閱讀 52,793評(píng)論 1 314
  • 那天汞扎,我揣著相機(jī)與錄音,去河邊找鬼赴精。 笑死佩捞,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蕾哟。 我是一名探鬼主播一忱,決...
    沈念sama閱讀 41,221評(píng)論 3 423
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼谭确!你這毒婦竟也來(lái)了帘营?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 40,174評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤逐哈,失蹤者是張志新(化名)和其女友劉穎芬迄,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體昂秃,經(jīng)...
    沈念sama閱讀 46,699評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡禀梳,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,770評(píng)論 3 343
  • 正文 我和宋清朗相戀三年杜窄,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片算途。...
    茶點(diǎn)故事閱讀 40,918評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡塞耕,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出嘴瓤,到底是詐尸還是另有隱情扫外,我是刑警寧澤,帶...
    沈念sama閱讀 36,573評(píng)論 5 351
  • 正文 年R本政府宣布廓脆,位于F島的核電站筛谚,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏停忿。R本人自食惡果不足惜驾讲,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,255評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望席赂。 院中可真熱鬧蝎毡,春花似錦、人聲如沸氧枣。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,749評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)便监。三九已至,卻和暖如春碳想,著一層夾襖步出監(jiān)牢的瞬間烧董,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,862評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工胧奔, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留逊移,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,364評(píng)論 3 379
  • 正文 我出身青樓龙填,卻偏偏與公主長(zhǎng)得像胳泉,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子岩遗,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,926評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容