zoukankan      html  css  js  c++  java
  • 在Linux下给mysql创建用户并分配权限及问题解决方案

    在linux下安装mysql请参考linux系统中安装mysql服务器详细步骤

    1.新建用户

      //登录MYSQL
      @>mysql -u root -p
      @>密码
      //创建用户
      mysql> insert into mysql.user(Host,User,Password) values(‘localhost’,'jeecn’,password(‘jeecn’));
      //刷新系统权限表
      mysql>flush privileges;
      这样就创建了一个名为:jeecn  密码为:jeecn  的用户。
      //退出后登录一下
      mysql>exit;
      @>mysql -u jeecn -p
      @>输入密码
      mysql>登录成功
      2.为用户授权
      //登录MYSQL(有ROOT权限)。我里我以ROOT身份登录。
      @>mysql -u root -p
      @>密码
      //首先为用户创建一个数据库(jeecnDB)
      mysql>create database jeecnDB;
      //授权jeecn用户拥有jeecn数据库的所有权限
      @>grant all privileges on jeecnDB.* to jeecn@localhost identified by ‘jeecn’;
      //刷新系统权限表
      mysql>flush privileges;
      mysql>其它操作
      //如果想指定部分权限给一用户,可以这样来写:
      mysql>grant select,update on jeecnDB.* to jeecn@localhost identified by ‘jeecn’;
      //刷新系统权限表。
      mysql>flush privileges;
      mysql> grant 权限1,权限2,…权限n on 数据库名称。表名称 to 用户名@用户地址 identified by ‘连接口令’;
      权限1,权限2,…权限n代表select,insert,update,delete,create,drop,index,alter,grant,references,reload,shutdown,process,file等14个权限。
      当权限1,权限2,…权限n被all privileges或者all代替,表示赋予用户全部权限。
      当数据库名称。表名称被*.*代替,表示赋予用户操作服务器上所有数据库所有表的权限。
      用户地址可以是localhost,也可以是ip地址、机器名字、域名。也可以用’%’表示从任何地址连接。
      ‘连接口令’不能为空,否则创建失败。
      例如:
      mysql>grant select,insert,update,delete,create,drop on vtdc.employee to jee@10.163.225.87 identified by ‘123′;
      给来自10.163.225.87的用户jee分配可对数据库vtdc的employee表进行select,insert,update,delete,create,drop等操作的权限,并设定口令为123。
      mysql>grant all privileges on vtdc.* to jee@10.10.10.87 identified by ‘123′;
      给来自10.163.225.87的用户jee分配可对数据库vtdc所有表进行所有操作的权限,并设定口令为123。
      mysql>grant all privileges on *.* to jee@10.10.10.87 identified by ‘123′;
      给来自10.163.225.87的用户jee分配可对所有数据库的所有表进行所有操作的权限,并设定口令为123。
      mysql>grant all privileges on *.* to jee@localhost identified by ‘123′;
      给本机用户jee分配可对所有数据库的所有表进行所有操作的权限,并设定口令为123。
      3.删除用户
      @>mysql -u root -p
      @>密码
      mysql>DELETE FROM mysql.user WHERE User=”jeecn”
      mysql>flush privileges;
      //删除用户的数据库
      mysql>drop database jeecnDB;
      4.修改指定用户密码
      @>mysql -u root -p
      @>密码
      mysql>update mysql.user set password=password(‘新密码’) where User=”jeecn” and Host=”localhost”;
      mysql>flush privileges;

      mysql>quit;

    5.如果使用root无法连接本地库的话:

    提示:1045 access denied for user 'root'@'localhost' using password yes
    前几天都好好的,昨天没弄,结果今天晚上过来提示上面的这个错误,重启mysql还是不可以
    网上的方法看了几个但是不知道怎么弄
    方法一: 
    # /etc/init.d/mysql stop 
    # mysqld_safe --user=mysql --skip-grant-tables --skip-networking & 
    # mysql -u root mysql 
    mysql> UPDATE user SET Password=PASSWORD(’newpassword’) where USER=’root’; 
    mysql> FLUSH PRIVILEGES; 
    mysql> quit 
    # /etc/init.d/mysql restart 
    # mysql -uroot -p 
    Enter password: <输入新设的密码newpassword> 
    mysql> 
    方法二: 
    直接使用/etc/mysql/debian.cnf文件中[client]节提供的用户名和密码: 
    # mysql -udebian-sys-maint -p 
    Enter password: <输入[client]节的密码> 
    mysql> UPDATE mysql.user SET Password=PASSWORD(’newpassword’) where USER=’root’; 
    mysql> FLUSH PRIVILEGES; 
    mysql> quit 
    # mysql -uroot -p 
    Enter password: <输入新设的密码newpassword> 
    mysql> 

  • 相关阅读:
    ASP.NET编程中非常有用的例子
    打包样式资源
    9.使用类的2个注意点
    面向对象案例
    super必须放到子类this之前
    PHP:根据二维数组中的某个字段进行排序
    Vuex的五个核心属性
    利用按钮控制listview的当前选择项,滚动条跟随动
    c#通过进程名字获取进程路径
    判断客户端是否安装realplayer
  • 原文地址:https://www.cnblogs.com/wujindong/p/5403498.html
Copyright © 2011-2022 走看看