前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python导出MySQL数据库中表的建表语句到文件

Python导出MySQL数据库中表的建表语句到文件

作者头像
星哥玩云
发布2022-08-16 14:38:13
3.2K0
发布2022-08-16 14:38:13
举报
文章被收录于专栏:开源部署

为了做数据对象的版本控制,需要将MySQL数据库中的表结构导出成文件进行版本化管理,试写了一下,可以完整导出数据库中的表结构信息

# -*- coding: utf-8 -*- import os import pymysql

class DBTool:

    conn = None     cursor = None

    def __init__(self,conn_dict):         self.conn = pymysql.connect(host=conn_dict['host'],                                     port=conn_dict['port'],                                     user=conn_dict['user'],                                     passwd=conn_dict['password'],                                     db=conn_dict['db'],                                     charset=conn_dict['charset'])         self.cursor = self.conn.cursor()

    def execute_query(self, sql_string):         try:             cursor=self.cursor             cursor.execute(sql_string)             list = cursor.fetchall()             cursor.close()             self.conn.close()             return list         except pymysql.Error as e:             print("mysql execute error:", e)             raise

    def execute_noquery(self, sql_string):         try:             cursor = self.cursor             cursor.execute(sql_string)             self.conn.commit()             self.cursor.close()             self.conn.close()         except pymysql.Error as e:             print("mysql execute error:", e)             raise

def main():     conn_dict = {'host': '127.0.0.1', 'port': 3306, 'user': '******', 'password': '******', 'db': 'test', 'charset': 'utf8'}     conn = DBTool(conn_dict)     sql_gettables = "select table_name from information_schema.`TABLES` WHERE TABLE_SCHEMA = 'databas_name';"     list = conn.execute_query(sql_gettables)

    # 文件目标路径,如果不存在,新建一个     mysql_file_path = 'D:\mysqlscript'     if not os.path.exists(mysql_file_path):         os.mkdir(mysql_file_path)

    mysqldump_commad_dict = {'dumpcommad': 'mysqldump --no-data ', 'server': '127.0.0.1', 'user': '******',                             'password': '******', 'port': 3306, 'db': 'databse_name'}

    if list:         for row in list:             print(row[0])             # 切换到新建的文件夹中             os.chdir(mysql_file_path)             #表名             dbtable = row[0]             #文件名             exportfile =  row[0] + '.sql'             # mysqldump 命令             sqlfromat = "%s -h%s -u%s -p%s -P%s %s %s >%s"             # 生成相应的sql语句             sql = (sqlfromat % (mysqldump_commad_dict['dumpcommad'],                                 mysqldump_commad_dict['server'],                                 mysqldump_commad_dict['user'],                                 mysqldump_commad_dict['password'],                                 mysqldump_commad_dict['port'],                                 mysqldump_commad_dict['db'],                                 dbtable,                                 exportfile))             print(sql)             result = os.system(sql)             if result:                 print('export ok')             else:                 print('export fail')

if __name__ == '__main__':     main()

建库测试

create database test_database charset utf8mb4 collate utf8mb4_bin;

use test_database;

create table table_a (     id int auto_increment not null,     name varchar(100) unique,     create_date datetime,     primary key pk_id(id),     index idx_create_date(create_date) );

insert into table_a(name,create_date) values ('aaaaaa',now()); insert into table_a(name,create_date) values ('bbbbbb',now());

create table table_b (     id int auto_increment not null,     name varchar(100) unique,     create_date datetime,     primary key pk_id(id),     index idx_create_date(create_date) ); insert into table_b(name,create_date) values ('aaaaaa',now()); insert into table_b(name,create_date) values ('bbbbbb',now());

执行的时候会提示一个警告,但是不影响最终的结果

mysqldump: [Warning] Using a password on the command line interface can be insecure.

导出建表语句会根据表的数据情况编号自增列,这是mysqldump的问题而不是导出的问题,如果有必要可以需求做相应的修改

去掉mysqldump导出表结构中备注信息

import os

filepath = "D:\\mysqlscript" # 切换到新建的文件夹中 os.chdir(filepath) pathDir = os.listdir(filepath) for file in pathDir:     lines = open(file, "r")     content = "use ***;"     content = content + "\n"     for line in lines:         print(line)         if not (str(line).startswith("--") or str(line).startswith("/*") ):             if(line!="\n" and str(line).startswith(") ENGINE")):                 content = content +"\n"+ ")"             else:                 content = content + line     #将提炼后的内容重新写入文件     print(content)     fp = open(file, 'w')     fp.write(content)     fp.close()

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档