iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL5.6添加root用户报错:Field 'ssl_cipher' doesn't have a default value怎么解决
  • 147
分享到

MySQL5.6添加root用户报错:Field 'ssl_cipher' doesn't have a default value怎么解决

2024-04-02 19:04:59 147人浏览 安东尼
摘要

这篇文章主要讲解了“Mysql5.6添加root用户报错:Field 'ssl_cipher' doesn't have a default value怎么解决”,文中的讲解内容简单

这篇文章主要讲解了“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条目信息:

  1. mysql> select Host,User,PassWord from user where User=\'root\';

  2. +--------------+------+-------------------------------------------+

  3. | Host         | User | Password                                  |

  4. +--------------+------+-------------------------------------------+

  5. | bidevedw\\_db| root | *D013A4E3A5BB01E4239D18D7E93B59B7D2B767AD |

  6. | ::1          | root | *D013A4E3A5BB01E4239D18D7E93B59B7D2B767AD |


  7. | %            | root | *D013A4E3A5BB01E4239D18D7E93B59B7D2B767AD |

  8. +--------------+------+-------------------------------------------+-

这样导致我在服务器本地登录的时候,解析的是以root@'%' 方式登录,然而这种方式登录的root是没有grant 权限,这使得不能给其他用户授权。

  1. *************************** 4. row ***************************

  2.                   Host: %

  3.                   User: root

  4.               Password: *D013A4E3A5BB01E4239D18D7E93B59B7D2B767AD

  5.            Select_priv: Y

  6.            Insert_priv: Y

  7.            Update_priv: Y

  8.            Delete_priv: Y

  9.            Create_priv: Y

  10.              Drop_priv: Y

  11.            Reload_priv: Y

  12.          Shutdown_priv: Y

  13.           Process_priv: Y

  14.              File_priv: Y

  15.             Grant_priv: N

  16.        References_priv: Y

  17.             Index_priv: Y

  18.             Alter_priv: Y

  19.           Show_db_priv: Y

  20.             Super_priv: Y

  21.  Create_tmp_table_priv: Y

  22.       Lock_tables_priv: Y

  23.           Execute_priv: Y

  24.        Repl_slave_priv: Y

  25.       Repl_client_priv: Y

  26.       Create_view_priv: Y

  27.         Show_view_priv: Y

  28.    Create_routine_priv: Y

  29.     Alter_routine_priv: Y

  30.       Create_user_priv: Y

  31.             Event_priv: Y

  32.           Trigger_priv: Y

  33. Create_tablespace_priv: Y

  34.               ssl_type:

  35.             ssl_cipher:

  36.            x509_issuer:

  37.           x509_subject:

  38.          max_questions: 0

  39.            max_updates: 0

  40.        max_connections: 0

  41.   max_user_connections: 0

  42.                 plugin: mysql_native_password

  43.  authentication_string:

  44.       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怎么解决这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL5.6添加root用户报错:Field 'ssl_cipher' doesn't have a default value怎么解决

本文链接: https://www.lsjlt.com/news/60777.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作