您好,登錄后才能下訂單哦!
這篇文章主要講解了“MySQL5.6添加root用戶報錯:Field 'ssl_cipher' doesn't have a default value怎么解決”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“MySQL5.6添加root用戶報錯:Field 'ssl_cipher' doesn't have a default value怎么解決”吧!
2012.14.15
MySQL: 5.6.19
剛剛忙完了零售測試環境的部署,現在處理上周遺留的問題。
由于user 表中確實localhost和127.0.0.1條目信息:
mysql> select Host,User,Password from user where User=\'root\';
+--------------+------+-------------------------------------------+
| Host | User | Password |
+--------------+------+-------------------------------------------+
| bidevedw\\_db| root | *D013A4E3A5BB01E4239D18D7E93B59B7D2B767AD |
| ::1 | root | *D013A4E3A5BB01E4239D18D7E93B59B7D2B767AD |
| % | root | *D013A4E3A5BB01E4239D18D7E93B59B7D2B767AD |
+--------------+------+-------------------------------------------+-
這樣導致我在服務器本地登錄的時候,解析的是以root@'%' 方式登錄,然而這種方式登錄的root是沒有grant 權限,這使得不能給其他用戶授權。
*************************** 4. row ***************************
Host: %
User: root
Password: *D013A4E3A5BB01E4239D18D7E93B59B7D2B767AD
Select_priv: Y
Insert_priv: Y
Update_priv: Y
Delete_priv: Y
Create_priv: Y
Drop_priv: Y
Reload_priv: Y
Shutdown_priv: Y
Process_priv: Y
File_priv: Y
Grant_priv: N
References_priv: Y
Index_priv: Y
Alter_priv: Y
Show_db_priv: Y
Super_priv: Y
Create_tmp_table_priv: Y
Lock_tables_priv: Y
Execute_priv: Y
Repl_slave_priv: Y
Repl_client_priv: Y
Create_view_priv: Y
Show_view_priv: Y
Create_routine_priv: Y
Alter_routine_priv: Y
Create_user_priv: Y
Event_priv: Y
Trigger_priv: Y
Create_tablespace_priv: Y
ssl_type:
ssl_cipher:
x509_issuer:
x509_subject:
max_questions: 0
max_updates: 0
max_connections: 0
max_user_connections: 0
plugin: mysql_native_password
authentication_string:
password_expired: N
解決思路分析:
把缺失的條目添加到user表中。
由于我也是這半年才真正的接觸MySQL。所以很多也是問度娘,我也以為像user表中添加記錄是使用INSERT into。但是這種方法會報錯:
ERROR 1364 (HY000): Field 'ssl_cipher' doesn't have a default value
這是因為user表中有幾個列是非空,而它的默認值是null .
| ssl_cipher | blob | NO | | NULL | |
| x509_issuer | blob | NO | | NULL | |
| x509_subject | blob | NO | | NULL | |
所以一般的insert into 都是給出前三列。而忽視了其他列。這種方式好像是在5.1之前可以使用的。我的是5.6。這種方式就行不通
解決方法:
GRANT USAGE ON *.* TO 'root'@'localhost' IDENTIFIED BY '123456' WITH GRANT OPTION;
GRANT USAGE ON *.* TO 'root'@'l127.0.0.1' IDENTIFIED BY '123456' WITH GRANT OPTION;
記得要刷新一下:flush privileges;
重新登錄mysql -uroot -p123456
查看當前登錄用戶和登錄的方式:
mysql> select user();
+----------------+
| user() |
+----------------+
| root@localhost |
+----------------+
1 row in set (0.00 sec)
這樣就可以不走@'%'
還可以修改root @'%'方式的權限:
mysql> GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY "123456" WITH GRANT OPTION;
Query OK, 0 rows affected (0.02 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.03 sec)
你權限的時候會顯示:Grant_priv: Y
這樣root用戶以@'%'方式就可以做grant操作
感謝各位的閱讀,以上就是“MySQL5.6添加root用戶報錯:Field 'ssl_cipher' doesn't have a default value怎么解決”的內容了,經過本文的學習后,相信大家對MySQL5.6添加root用戶報錯:Field 'ssl_cipher' doesn't have a default value怎么解決這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。