mysql客戶端修改sqlmode_MySQL修改sql_mode

一 ERR 1067引發的血案

今天在Navicat中運行sql語句創建數據表出現了錯誤Err 1067。而這條語句在有些同事的mysql上是正確的,但是在有些人那里就報錯。

7e722e22e276

QQ截圖20170811143551.png

原因竟然是timestamp的默認值不正確。

查閱資料得知,mysql5.7版本中有了一個STRICT mode(嚴格模式),而在此模式下默認是不允許設置日期的值為全0值的,所以想要解決這個問題,就需要修改sql_mode的值。

二 問題的源頭sql_mode

我們可以進入到mysql中一探sql_mode的究竟。首先進入到mysql的安裝目錄下的bin目錄,使用管理員用戶登錄mysql數據庫。

使用命令 mysql –h localhost –u root –p 其中-h是指定主機名或IP地址, -u是指定用戶, -p是使用密碼登錄。

7e722e22e276

QQ截圖20170811141126.png

使用命令 select @@sql_mode; 可以查看sql_mode的值。如果輸入了命令卻沒有反應,只是單單出現了-> ,那么我想你多半是應該像我一樣,沒有輸入 “;”。

7e722e22e276

QQ截圖20170811141139.png

通過上圖中的結果我們可以看到sql_mode中有NO_ZERO_IN_DATE和NO_ZERO_DATE,在命令行中輸入 set sql_mode=(select replace(@@sql_mode,

'NO_ZERO_IN_DATE,NO_ZERO_DATE','')); 可以修改當前session的sql_mode。

7e722e22e276

QQ截圖20170811142804.png

之后可以查看一下sql_mode的值。可以發現已經成功去掉了NO_ZERO_IN_DATE和NO_ZERO_DATE。

7e722e22e276

QQ截圖20170811142815.png

重新運行了一下建表的sql語句,發現沒什么卵用,依然Err 1067。不要想什么姿勢不對的問題了,只是全局的sql_mode沒有設置而已,而這里設置的sql_mode對大局根本沒有影響。

使用命令 select @@global.sql_mode; 可以查看全局sql_mode的值。

7e722e22e276

QQ截圖20170811144154.png

剩下的操作與之前的sql_mode設置是同理可證的,只是將之前sql_mode的地方都換成了@@global.sql_mode,如圖。

7e722e22e276

QQ截圖20170811144607.png

完成設置之后可以在Navicat中重新運行一下sql語句了,不過在那之前要先重新連接數據庫,不然依然Rrr 1067。別問我為什么,叫我雷鋒就好。運行結果如下:

7e722e22e276

QQ截圖20170811144805.png

好了,這次表是創建成功了的,而且換了一個錯誤Err 1055,翻譯過來就是“無法給包含一個非聚合的列information_schema.PROFILING.SEQ進行分組,這個功能不再依賴分組,且與新的規則不兼容sql_mode=only_full_group_by”。也說了這是由于sql_mode中的“ONLY_FULL_GROUP_BY”導致的。可以再次修改sql_mode。

7e722e22e276

QQ截圖20170811145725.png

刪除之前創建好的表,重新連接數據庫,運行sql語句,然后就棒棒棒了。

7e722e22e276

QQ截圖20170811145933.png

當然這種解決方法只是揚湯止沸,一旦重啟mysql數據庫,之前費了狼勁設置的一堆值一夜回到解放前。

這也是有解決辦法的,下面會給大家介紹。

三 設置sql_mode

可以通過修改配置文件的方式設置sql_mode,這樣在數據庫重啟之后sql_mode的值也不會改變。

首先我們需要知道的是mysql的配置文件的加載順序。進入到數據庫安裝目錄的bin目錄下,使用命令

mysqld --verbose –help可以看到,不過這個命令的輸出結果太長了,我暫時沒有找到更合適的命令來查看。加載順序如圖:

7e722e22e276

QQ截圖20170811151737.png

這些配置文件在加載時,后加載的會將之前加載的配置文件中的相同的值覆蓋。不過我只在mysql的安裝目錄下找到了一個名字很像的配置文件,其余的都沒有找到。

7e722e22e276

QQ截圖20170811152424.png

將這個文件備份好之后,修改名稱為my.ini,與給出的加載配置文件順序中的文件對應。然后打開文件,我這里的配置文件中的sql_mode只有兩個值。

7e722e22e276

QQ截圖20170811152716.png

重啟數據庫后,使用命令查看sql_mode的值,發現與配置文件中完全吻合,搞定!

7e722e22e276

QQ截圖20170811152945.png

附加幾種常見的sql_mode值的介紹:

幾種常見的mode介紹

ONLY_FULL_GROUP_BY:

出現在select語句、HAVING條件和ORDER BY語句中的列,必須是GROUP BY的列或者依賴于GROUP BY列的函數列。

NO_AUTO_VALUE_ON_ZERO:

該值影響自增長列的插入。默認設置下,插入0或NULL代表生成下一個自增長值。如果用戶

希望插入的值為0,而該列又是自增長的,那么這個選項就有用了。

STRICT_TRANS_TABLES:

在該模式下,如果一個值不能插入到一個事務表中,則中斷當前的操作,對非事務表不做限制

NO_ZERO_IN_DATE:

這個模式影響了是否允許日期中的月份和日包含0。如果開啟此模式,2016-01-00是不允許的,但是0000-02-01是允許的。它實際的行為受到 strict mode是否開啟的影響1。

NO_ZERO_DATE:

設置該值,mysql數據庫不允許插入零日期。它實際的行為受到 strict

mode是否開啟的影響2。

ERROR_FOR_DIVISION_BY_ZERO:

在INSERT或UPDATE過程中,如果數據被零除,則產生錯誤而非警告。如

果未給出該模式,那么數據被零除時MySQL返回NULL

NO_AUTO_CREATE_USER:

禁止GRANT創建密碼為空的用戶

NO_ENGINE_SUBSTITUTION:

如果需要的存儲引擎被禁用或未編譯,那么拋出錯誤。不設置此值時,用默認的存儲引擎替代,并拋出一個異常

PIPES_AS_CONCAT:

將”||”視為字符串的連接操作符而非或運算符,這和Oracle數據庫是一樣的,也和字符串的拼接函數Concat相類似

ANSI_QUOTES:

啟用ANSI_QUOTES后,不能用雙引號來引用字符串,因為它被解釋為識別符

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531767.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531767.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531767.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

零基礎mysql項目實例_MySQL-零基礎開發

1.終端下連接mysql服務mysql -uroot -p回車后輸入設定的密碼即可。進去后每條命令結尾要帶分號;退出命令exit單行注釋有兩種:#  或 --空格。多行注釋/*  */2.基本命令集合針對數據庫:use sys;  show databases;查看當前操作的數據庫&a…

hdu2066一個人的旅行(多源點多匯點的最短路徑問題)

/*思路:多源點,多會點的最短路徑!將最小號-1的節點但最源點,將最大號+1的點當作匯點!將問題轉變成從一個源點到一個匯點的最短路徑的問題&#xf…

php設置mysql 編碼_php怎么設置mysql編碼?

在php中,可以使用mysql_query()函數來設置mysql編碼,語法“mysql_query(SET NAMES 編碼方式);”;mysql_query()函數需要放置在mysql_connect()語句之后。在php中,可以使用mysql_query()函數來設置mysql編碼。在PHP連接數據庫的時候…

nyoj 925 國王的煩惱(最小生成樹)

1 /*2 題意:N個城市中每兩個城市有多條路徑連接,可是因為路徑存在的天數是有限的!以為某條路經不存在了3 導致N個城市不能連通了,那么村名們就會抗議!問一共會有多少次抗議!4 5 思路&#…

golang 切片 接口_Go編程模式:切片,接口,時間和性能

在本篇文章中,我會對 Go 語言編程模式的一些基本技術和要點,這樣可以讓你更容易掌握 Go 語言編程。其中,主要包括,數組切片的一些小坑,還有接口編程,以及時間和程序運行性能相關的話題。本文是全系列中第 1…

poj 3352Road Construction(無向雙連通分量的分解)

1 /*2 題意:給定一個連通的無向圖G,至少要添加幾條邊,才能使其變為強連通圖(指的是邊強聯通)。 3 思路:利用tarjan算法找出所有的雙聯通分量!然后根據low[]值的不同將雙聯通分量4 進行…

jsp中去掉超鏈接下劃線嗎_網頁中如何去掉超鏈接的下劃線

展開全部a:link {text-decoration: none;}a:visited {text-decoration: none;color: #6B6C70;}其中的text-decoration: none;是消除下劃線例如:只需加入一段代碼32313133353236313431303231363533e59b9ee7ad9431333337393534:td,body { font-size: 9pt}a…

POJ 2312Battle City(BFS-priority_queue 或者是建圖spfa)

1 /*2 bfs搜索&#xff01;要注意的是點與點的權值是不一樣的哦&#xff01;3 空地到空地的步數是1&#xff0c; 空地到墻的步數是2&#xff08;轟一炮移過去&#xff09;4 所以用到優先隊列進行對當前節點步數的更新&#xff01; 5 */6 #include<iostream>7 #…

linux訓練python出現killed_Linux 查看進程被殺死的詳情

運行寫的不太完善的爬蟲程序, 未限制任務隊列大小, 再加上本子配置不高, 爬取網站到第3層大半時, 內存不足了...進程運行太猛, 導致系統 out of memory, 那么此進程被系統的oom killer殺死.此時終端顯示 "Killed" 或 "已殺死".查看相關信息的命令:dmesg | …

mysql 123456_MySQL字符串中抽取數值的方法 select -(-'123456@163.com'); 很牛逼

MySQL的字符串函數非常多&#xff0c;以至于有時候我不知道該如何靈活的使用這些函數。字符串基本信息函數 collation convert&#xff0c;char_length等加密函數 password(x)&#xff0c;encode, aes_encrypt字符串連接函數 concat(x1,x2,….)修剪函數 trim,ltrim,…

ZZUOJ 1199 大小關系(拓撲排序,兩種方法_判斷入度和dfs回路判斷)

1 /*2 這道題如果按照度為0的節點來判斷的時候,將度為0的節點和其相連的節點&#xff08;度數并減去1&#xff09; 3 從圖中去掉&#xff0c;如果度為0的節點的個數為0個但是圖中的節點沒有都去掉的 時候那么說明4 出現了回路!用這種方法必須將重邊去除掉&#xff01; …

matlab畫圖plot設置字體_R語言科研畫圖字體格式設置

作者&#xff1a;黃天元&#xff0c;復旦大學博士在讀&#xff0c;熱愛數據科學與開源工具&#xff08;R&#xff09;&#xff0c;致力于利用數據科學迅速積累行業經驗優勢和科學知識發現&#xff0c;涉獵內容包括但不限于信息計量、機器學習、數據可視化、應用統計建模、知識圖…

hdu3339 In Action(Dijkstra+01背包)

1 /*2 題意&#xff1a;有 n 個站點&#xff08;編號1...n&#xff09;&#xff0c;每一個站點都有一個能量值&#xff0c;為了不讓這些能量值連接起來&#xff0c;要用 3 坦克占領這個站點&#xff01;已知站點的 之間的距離&#xff0c;每個坦克從0點出發到某一個站點&…

在手機上安裝youget_you-get 安裝和用法

Usage: you-get [OPTION]... [URL]...Startup options:-V | --version 版本信息-h | --help 幫助Dry-run options: (no actual downloading)-i | --info 列出所有可獲取的視頻信息-u | --url 打印URLs的提取出信息&#xff0c;真實鏈接地址--json 打印URLs的JSON格式Download o…

ZZUOJ1196: 單調數

1 /*2 注意的事項:是輸出小于 10^n的正整數的個數哦&#xff01;開始的時候總比樣例輸出多一個數&#xff0c;3 糾結了好久&#xff0c;原來是 0加了進去了&#xff01;4 5 dpI[n][m]表示的是第n位添加數字m&#xff08;0....9&#xff09;的構成單調遞增數個數 6 …

mac 愛普生打印機驅動_epson l360 mac版驅動下載-愛普生l360驅動Mac版最新版 - 極光下載站...

愛普生l360驅動蘋果電腦版是專為mac用戶所設計打造&#xff0c; 當你的電腦中安裝了本驅動程序以后&#xff0c;就可以非常輕松的進行操作打印了&#xff0c;與該型號的打印機相匹配&#xff0c;將會帶給你最流暢的打印體會&#xff01;愛普生l360打印機介紹--打印質量分辨率可…

mysql 生成 javabean_從MySQL快速生成JavaBean

SELECTCONCAT(/**\n*,COLUMN_COMMENT,\n*/\n), -- 注解CONCAT(Column(name ",column_name,")\n), -- JPA字段注解( -- 根據表定義的字段生成相應的 Java類型CASEdata_typeWHEN varcharTHEN private StringWHEN bigintTHEN private IntegerWHEN intTHEN private Inte…

poj2253 Frogger(最短路變型或者最小生成樹)

1 /*2 題意&#xff1a;就是源點到終點有多條的路徑&#xff0c;每一條路徑中都有一段最大的距離&#xff01;3 求這些路徑中最大距離的最小值&#xff01;4 5 Dijkstra, Floyd, spfa都是可以的&#xff01;只不過是將松弛的條件變一下就行了&#xff01;6 7 …

python包mdure_Python hashlib模塊實例使用詳解

這篇文章主要介紹了Python hashlib模塊實例使用詳解,文中通過示例代碼介紹的非常詳細&#xff0c;對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下hashlib模塊主要的作用&#xff1a;加密保護消息安全&#xff0c;常用的加密算法如MD5&#xff0c;SHA1等。1、…

UVAoj 348 - Optimal Array Multiplication Sequence

1 /*2 題意&#xff1a;矩陣相乘的最少的步數3 dp[i][j]min(dp[i][j], dp[i][k]dp[k1][j]num[i-1]*num[k]*num[j]);4 表示的是第i個矩陣到第j個矩陣相乘的最少步數5 sign[i][j]表示的是第i個矩陣到第j個矩陣相乘的最少步數是由第i個矩陣到第sign[i][j]個矩陣相…