国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python批量導出導入MySQL用戶的方法

2019-11-25 18:37:58
字體:
來源:轉載
供稿:網友

數據庫遷移(A -> B),需要把用戶也遷移過去,而用戶表(mysql.user)有上百個用戶。有2種方法進行快速遷移:
1,在同版本的條件下,直接備份A服務器的mysql數據庫,還原到B服務器。
2,要是不同版本的數據(5.1 -> 5.5),很可能mysql數據庫下面的一些表結構,甚至表數據的默認值都不一樣,按照1的方法進行遷移,雖然最后也是可以正常訪問,但是還是有些不太放心,很可能會影響到了B服務器上的MySQL,這樣就需要用命令行來生成帳號了,這樣是最安全和放心的。下面用python腳本來進行批量導出:

復制代碼 代碼如下:

#!/bin/env python
# -*- encoding: utf-8 -*-
#-----------------------------------------
# Name:        mysql_user_dump.py
# Purpose:     批量導出用戶
# Author:      zhoujy
# Created:     2013-05-28
#-----------------------------------------
import MySQLdb

def get_data(conn):
    query  = 'select user,host from mysql.user order by user'
    cursor = conn.cursor()
    cursor.execute(query)
    lines  = cursor.fetchall()
    return lines

def output_data(conn,rows):
    for user,host in rows:
        query  = "show grants for '%s'@'%s'" %(user,host)
        cursor = conn.cursor()
        cursor.execute(query)
        show_pri = cursor.fetchall()
        for grants_command in show_pri:
            print ''.join(grants_command)+';'
        print ''

if __name__ =='__main__':
    conn = MySQLdb.connect(host='localhost',user='root',passwd='123456',db='mysql',port=3306,charset='utf8')
    rows  = get_data(conn)
    output_data(conn,rows)

運行:python mysql_user_dump.py

復制代碼 代碼如下:

GRANT REPLICATION SLAVE ON *.* TO 'rep'@'192.168.234.%' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9';

GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' WITH GRANT OPTION;

GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.234.%' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9';

GRANT USAGE ON *.* TO 'test'@'192.168.234.%' IDENTIFIED BY PASSWORD '*2A032F7C5BA932872F0F045E0CF6B53CF702F2C5';
GRANT SELECT, INSERT, UPDATE, DELETE ON `test`.* TO 'test'@'192.168.234.%';

GRANT USAGE ON *.* TO 'zzz_test'@'192.168.234.%' IDENTIFIED BY PASSWORD '*2A032F7C5BA932872F0F045E0CF6B53CF702F2C5';
GRANT SELECT, INSERT, UPDATE, DELETE ON `zzz%`.* TO 'zzz_test'@'192.168.234.%';

最后把這些命令在B上面執行就好了,也可以在執行腳本的時候重定向到一個sql文件:如:user.sql,在到B服務器的數據庫里面執行source user.sql 就完成了導入工作。
第2個方法最好,不需要1里面的刪表和重建表的操作,最安全。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 横峰县| 法库县| 固阳县| 蓝山县| 桐城市| 中方县| 兴安县| 当阳市| 佛冈县| 罗甸县| 汨罗市| 彩票| 隆回县| 宣恩县| 大竹县| 鹤山市| 九江市| 兴国县| 富阳市| 宾阳县| 灵山县| 逊克县| 武清区| 扎囊县| 尉氏县| 棋牌| 凤冈县| 邹平县| 大厂| 牙克石市| 永顺县| 杭锦后旗| 嫩江县| 富锦市| 涿州市| 南郑县| 柞水县| 洞头县| 垫江县| 陈巴尔虎旗| 肃北|