• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    运用Python快速的对MySQL数据库进行重命名

    对数据库的表进行重命名可以使用以下原生sql:

    RENAME TABLE old_table TO new_table;  
    

    窘境:但是MySQL并没有直接支持对数据库进行重命名

    那么如何运用Python快速的对现有的数据库进行重命名呢?

    比如项目初期,对数据库的命名(db_ridingroad)没有规划好,
    然后在下面创建了大量的表和写入了大量的数据,现在需要对数据库的名字进行重命名为(db_news_website)

    常规思路

    下面的方法步骤较为繁琐

    -- 数据库备份
    mysqldump –u [UserName] –p[Password] –R [DB_Name] > [DB_Name].sql
    -- 创建新数据库
    create database [New_DB_Name];
    -- 把备份的数据导入到新数据库
    mysql –u [UserName] –p[Password] [New_DB_Name]  [DB_Name].sql
    -- 删除旧数据库
    drop database [DB_Name];
    

    更快捷的方法

    只需要执行下面这条命令即可

    python rename_database.py old_db_name new_db_name
    

    我们可以使用表重命名的方法,把表重命名到新的数据库之下。基本逻辑如下:

    1. 创建新数据库
    2. 获取旧数据库下所有的表名
    3. 把表重命名到新的数据库名下
    4. 删除旧数据库

    下面使用Python代码去实现,主要代码(完整代码见文末):

    def rename_db(old_name, new_name):
        """
        数据库重命名
        :param old_name: 原来的数据库名
        :param new_name: 新数据库名
        :return: 成功返回True, 失败返回False
        """
        # 获取所有的表名
        sql = """SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE table_schema=%s"""
        conn, cursor = context()
        try:
            # 创建新数据库名
            cursor.execute('create database if not exists {}'.format(new_name))
    
            cursor.execute(sql, (old_name, ))
            results = cursor.fetchall()
            # 获取表明,循环处理放到新的数据库名下
            for r in results:
                tb = r['TABLE_NAME']
                rename_sql = """RENAME TABLE {}.{} to {}.{}""".format(old_name, tb, new_name, tb)
                cursor.execute(rename_sql)
            # 把旧数据库删掉
            cursor.execute('drop database {}'.format(old_name))
        except Exception as ex:
            conn.rollback()
            print("rename_db Exception: {},{}".format(sql, ex))
            return False
        else:
            # 如果没有发生异常,则提交事务
            conn.commit()
        finally:
            conn.close()
        return True
    

    使用方法

    1.安装PyMySQL

    pip install PyMySQL
    

    2.修改脚本中关于数据库账号配置信息部分

    MYSQL_HOST = '127.0.0.1'
    MYSQL_PORT = 3306
    MYSQL_USER = 'ridingroad'
    MYSQL_PASSWORD = 'xxxxyyyy'
    MYSQL_DATABASE = 'db_ridingroad'
    

    3.切换到脚本所在目录,执行以下命令即可(数据无价,请先mysqldump备份)

    python rename_database.py old_db_name new_db_name
    

    完整代码如下:

    import sys
    import pymysql
    
    
    MYSQL_HOST = '127.0.0.1'
    MYSQL_PORT = 3306
    MYSQL_USER = 'ridingroad'
    MYSQL_PASSWORD = 'xxxxyyyy'
    MYSQL_DATABASE = 'db_ridingroad'
    MYSQL_CHARSET = 'utf8'
    
    
    def context(is_dict_cursor=True, database=MYSQL_DATABASE):
        """
        创建数据库连接, 数据以字典结构返回
        :param is_dict_cursor: 是否返回字典结构的数据
        :param database: 默认连接的数据库
        :return: 返回一个连接和一个浮标
        """
        try:
            config = {
                'host': MYSQL_HOST,
                'port': MYSQL_PORT,
                'user': MYSQL_USER,
                'password': MYSQL_PASSWORD,
                'database': database,
                'charset': MYSQL_CHARSET,
            }
    
            conn = pymysql.connect(**config)
            if is_dict_cursor:
                cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
            else:
                cursor = conn.cursor()
            return conn, cursor
        except Exception as ex:
            print("connect database failed, {},{}".format(400, ex))
            raise Exception({'code': 400, 'msg': ex})
    
    
    def rename_db(old_name, new_name):
        """
        数据库重命名
        :param old_name: 原来的数据库名
        :param new_name: 新数据库名
        :return: 成功返回True, 失败返回False
        """
        # 获取所有的表名
        sql = """SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE table_schema=%s"""
        conn, cursor = context()
        try:
            conn.begin()
            # 创建新数据库名
            cursor.execute('create database if not exists {}'.format(new_name))
    
            cursor.execute(sql, (old_name, ))
            results = cursor.fetchall()
            # 获取表明,循环处理放到新的数据库名下
            for r in results:
                tb = r['TABLE_NAME']
                rename_sql = """RENAME TABLE {}.{} to {}.{}""".format(old_name, tb, new_name, tb)
                cursor.execute(rename_sql)
            # 把旧数据库删掉
            cursor.execute('drop database {}'.format(old_name))
        except Exception as ex:
            conn.rollback()
            print("rename_db Exception: {},{}".format(sql, ex))
            return False
        else:
            # 如果没有发生异常,则提交事务
            conn.commit()
        finally:
            conn.close()
        return True
    
    
    if __name__ == '__main__':
        old_db = sys.argv[1]
        new_db = sys.argv[2]
        rename_db(old_name=old_db, new_name=new_db)
    

    以上就是运用Python快速的对MySQL数据库进行重命名的详细内容,更多关于python 重命名MySQL数据库的资料请关注脚本之家其它相关文章!

    您可能感兴趣的文章:
    • python教程命名元组示例分析
    • 一篇文章教你用Python实现一键文件重命名
    • Python如何根据照片修改时间重命名并排序详解
    • python文件名批量重命名脚本实例代码
    • Python中os模块的简单使用及重命名操作
    • 一文理解Python命名机制
    上一篇:Python使用fliecmp实现比较文件的操作
    下一篇:Python中Pyenv virtualenv插件的使用
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    运用Python快速的对MySQL数据库进行重命名 运用,Python,快速,的,对,MySQL,