程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL中導出用戶權限設置的腳本分享,mysql用戶權限

MySQL中導出用戶權限設置的腳本分享,mysql用戶權限

編輯:MySQL綜合教程

MySQL中導出用戶權限設置的腳本分享,mysql用戶權限


在對MySQL數據庫進行遷移的時候,有時候也需要遷移源數據庫內的用戶與權限。對於這個遷移我們可以從mysql.user表來獲取用戶的相關權限來生成相應的SQL語句,然後在目標服務器上來執行生成的SQL語句即可。本文提供了生成提取用戶權限的腳本並給出演示。

1、生成用戶權限的腳本

復制代碼 代碼如下:
[root@HKBO ~]# more exp_grant.sh 
#!/bin/bash 
#Function export user privileges 
 
pwd=123456 
expgrants() 

  mysql -B -u'root' -p${pwd} -N $@ -e "SELECT CONCAT( 
    'SHOW GRANTS FOR ''', user, '''@''', host, ''';' 
    ) AS query FROM mysql.user" | \ 
  mysql -u'root' -p${pwd} $@ | \ 
  sed 's/\(GRANT .*\)/\1;/;s/^\(Grants for .*\)/-- \1 /;/--/{x;p;x;}' 

expgrants > ./grants.sql 

2、生成權限SQL腳本

復制代碼 代碼如下:
[root@HKBO ~]# ./exp_grant.sh  
 
[root@HKBO ~]# head grants.sql 
-- Grants for [email protected]  
GRANT ALL PRIVILEGES ON *.* TO 'root'@'127.0.0.1' IDENTIFIED BY PASSWORD '*EB3EA446C759C9DA93F84FCB56430DBEF051A9DD' WITH GRANT OPTION; 
GRANT ALL PRIVILEGES ON `CNBO0815`.* TO 'root'@'127.0.0.1' WITH GRANT OPTION; 
 
-- Grants for [email protected].%  
GRANT ALL PRIVILEGES ON *.* TO 'root'@'172.16.10.%' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9'; 
 
-- Grants for [email protected].%  
GRANT USAGE ON *.* TO 'CNBO'@'192.168.1.%' IDENTIFIED BY PASSWORD '*ABD91BAD4A3448428563952E281015B237310EA8'; 
         ........................... 
 

3、在目標服務器上執行腳本

將生成的腳本在目標服務器上執行即可。 mysql -uname -ppwd <grants.sql

需要注意:

a、目標服務上為非空服務器,已經存在一些賬戶及權限應考慮會覆蓋的問題。
b、如果僅僅需要遷移非root用戶,可以在原腳本中添加過濾條件,即 where user<>'root' 。


MYSQL怎設置用戶權限

grant all privileges on *.* to root@'%' identified by '12345678' with grant option;
實施這個吧,正常的話不會出錯
Mysql的基礎知識可以去這個地方查看
 

mysql 權限設置

在mysql命令行中,用grant語句創建用戶

grant 權限 on 數據庫名.數據庫表 to username@'%' identified by 'userpwd'.

你的情況 可以
grant all on dbname.table0 to 'username'@'%' identified by 'pwd';
grant all on dbname.table1 to 'username'@'%' identified by 'pwd';
……
……

有些數據庫中可以這樣
grant all on dbname,table0,dbname.table1 to 'username'@'%' identified by 'pwd';
或者
grant all on dbname,table0 dbname.table1 to 'username'@'%' identified by 'pwd';

但是mysql中似乎不行,至少我用的5.0.41中,我一直沒搞懂該怎麼做才能一條語句grant很多指定的table到一個賬號中,只好分開做了。
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved