当前位置: 首页 > 编程日记 > 正文

自动获取mysql建表语句_脚本工具---自动解析mysql建表语句,生成sqlalchemy表对象声明...

常规建表语句:

CREATE TABLE `test_table` (

`id` int(11) NOT NULL,

`name` char(64) NOT NULL,

`password` char(64) NOT NULL,

PRIMARY KEY (`name`,`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='test';

解析脚本代码:

# coding:utf-8

import re

deftable_design_transfer(table_design):

type_map= {"varchar":"String","datetime":"DateTime","bigint":"BigInteger","smallint":"SmallInteger","tinyint":"SmallInteger","text":"Text","int":"Integer","double":"Float","char":"String","set":"Enum"}

l= table_design.split("\n") #表设计行拆分

length =len(l)

s=[]

primary_key_l=[]for i in range(length): #遍历表设计行

j = l[length-1-i].strip().split(" ") #倒序遍历,并按空格切分

if len(j)>2: #只关注行长度超过2的元素

column = j[0].replace("`","")

i_type= j[1]if column == "PRIMARY":

primary_key_l= re.sub(r'`|\(|\)','',j[2]).split(",") #拿到主键key

continue

elif column == "CREATE": #获取表名

table_name = j[2].replace("`","")

s.append(" "+'__tablename__ = "%s"' %table_name)

s.append("class %s(Base):" %table_name)continue

elif column in ("UNIQUE",")","KEY"): #非表列名,跳过

continue

if i_type in type_map.keys(): #类型存在映射表中

i_type = i_type.replace(i_type,type_map[i_type])+"()"

elif "(" in i_type and i_type.split("(")[0] in type_map.keys(): #类型有长度声明,提取类型字段,找到映射表映射value,并替换

old_type = i_type.split("(")[0]

new_type= type_map[i_type.split("(")[0]]

i_type=i_type.replace(old_type,new_type)else:print "Catch any case not in type_map:%s" %i_typeif column in primary_key_l: #列名存在主键数组中

i_type = i_type + ", primary_key=True"s.append(" "+column + "= Column(" + i_type + ")")for i in s[::-1]: #反序输出

print i

输出结果:

classtest_table(Base):__tablename__ = "test_table"id= Column(Integer(11), primary_key=True)

name= Column(String(64), primary_key=True)

password= Column(String(64))

sqlalchemy库官方文档:http://docs.sqlalchemy.org/en/latest/contents.html

sqlalchemy库官方文档(中文):http://www.cnblogs.com/iwangzc/p/4112078.html(感谢作者的分享)

faker库官方文档:https://faker.readthedocs.io/en/master/locales/zh_CN.html

faker库博客:https://www.jianshu.com/p/6bd6869631d9

相关文章:

对云风 cstring 第二次解析

前言 从明天起 关心粮食和蔬菜 我有一所房子 面朝大海 春暖花开 本文前提条件 1.了解 posix 线程 2.了解 原子操作 3.具备简单C基础,或者 你也敲一遍. 如果上面不太清楚,你可以翻看我以前的博客,或者百度搜索. 结论 1.云风前辈的 玩具 cstring 有点坑, 内存管理很随意(也可能时…

C# 获取当前路径方法

//获取包含清单的已加载文件的路径或 UNC 位置。 public static string sApplicationPath Assembly.GetExecutingAssembly ( ).Location; //result: X:\xxx\xxx\xxx.dll (.dll文件所在的目录.dll文件名) //获取当前进程的完整路径,包含文件名(进程名)。 string st…

土地档案管理系统需求分析

土地档案管理系统需求分析 1 项目背景 随着国土大面积调查工作的全面展开和城镇地籍管理工作得以日趋细化,各种野外调查数据,不同比例尺图件资料急剧增加。特别是城市建设的空前发展以及土地有偿使用法规的实施,使得地籍变更日益频繁、地籍信…

mysql8.0 服务移除_Linux下彻底删除Mysql 8.0服务的方法

观看本文前最好有一定的Linux命令基础,具体为centos7.3环境中清除使用yum安装的Mysql卸载前请先关闭Mysql服务service mysql stop使用 rpm 命令的方式查看已安装的mysqlrpm -qa|grep mysql开始卸载Mysql服务使用yum安装需要先进行清除服务等yum remove mysql mysql-…

老李推荐:第14章4节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-装备ViewServer-端口转发 1...

老李推荐:第14章4节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-装备ViewServer-端口转发 在初始化HierarchyViewer的实例过程中,HierarchyViewer会调用自己的成员方法setupViewServer来把ViewServer装备好,那么我们这里先看下这个方法…

泛型详解 高级进阶

泛型详解 高级进阶 转载于:https://www.cnblogs.com/thiaoqueen/p/10830499.html

vim 的中文编码问题

在vim编辑的时候会出现中文编码问题,我们可以这样解决在/usr/share/vim/的目录下有一个vimrc文件打开这个文件,你可能要用sudo打开然后在最后输入这行代码保存即可:$> sudo vim /usr/share/vim/vimrc set fileencodingsutf-8,gb2312,gbk,g…

mysql回表_到底什么情况下mysql innodb会发生回表操作?

谢邀MySQL innodb的主键索引是簇集索引,也就是索引的叶子节点存的是整个单条记录的所有字段值,不是主键索引的就是非簇集索引,非簇集索引的叶子节点存的是主键字段的值。回表是什么意思?就是你执行一条sql语句,需要从两…

经验分享:CSS浮动(float,clear)通俗讲解

很早以前就接触过CSS,但对于浮动始终非常迷惑,可能是自身理解能力差,也可能是没能遇到一篇通俗的教程。 前些天小菜终于搞懂了浮动的基本原理,迫不及待的分享给大家。 写在前面的话: 由于CSS内容比较多,小菜…

前端开发学习Day27

第27天,我只做了一个案例。布局部分花了一整个上午,很乱。代码还是写的少,没有思路。下午好不容易做好了布局,写脚本的时候又被卡死,我现在严重怀疑自己的大脑是怎么长的……本着不抛弃不放弃的原则,晚上找…

对象模型创建SharePoint2010多选字段SPFieldMultiChoice

在使用页面方式创建SharePoint 2010的选项(Choice)字段时,选项字段的显示方式有3种:下拉列表、单选按钮、多选。但是如果使用对象模型创建时,下拉列表和单选按钮只能使用SPFieldChoice类来创建,而多选显示方式就要使用SPFieldMult…

docker mysql忘记密码_docker基于mysql镜像构建mysql容器忘记密码解决办法

环境:[rootmaster-106 ~]# cat /etc/redhat-releaseCentOS Linux release 7.6.1810 (Core)[rootmaster-106 ~]# docker --versionDocker version 19.03.13, build 4484c46d9dMySQL 5.7.31# 进入mysql容器[rootmaster-106 ~]# docker ps|grep mysql05759803adb9 mysq…

Android App优化之延长电池续航时间

禁用广播接收器 确保广播接收器在真正须要时才运行指令&#xff0c;在onResume中当中广播接收器&#xff0c;在onPause中禁用。 在manifest文件里声明广播接收器时&#xff0c;事先默认配置成禁用的 <receiver android:name".BatterReceiver" android:enabled&quo…

myeclipse中安装svn插件

1、下载最新的SVN包(我下的是1.0.6版)&#xff1a; http://subclipse.tigris.org/servlets/ProjectDocumentList?folderID2240 2、在你的磁盘上任意位置创建文件夹&#xff1a;“myplugins/svn”。名字可以任取&#xff0c;为了方便插件管理&#xff0c;建议名称为“myplugins…

字节码学院全栈学习笔记

今天正式加入字节码学院&#xff0c;努力学习Java全栈&#xff0c;争取在6个月内称为一个了解软件行业的人&#xff0c;本人在这里立铁为证&#xff1a; 搭建vue 组件化开发环境时&#xff0c;需要安装node.js step 01: nodejs 安装 sudo apt updatesudo apt install nodejsno…

mysql 索引 二叉树_MySQL 的索引,为什么是 B+而不是平衡二叉树

数据库为什么使用 B 树&#xff1f;前言讲到索引&#xff0c;第一反应肯定是能提高查询效率。例如书的目录&#xff0c;想要查找某一章节&#xff0c;会先从目录中定位。如果没有目录&#xff0c;那么就需要将所有内容都看一遍才能找到。索引的设计对程序的性能至关重要&#x…

Spring Boot 2 快速教程:WebFlux 快速入门(二)

2019独角兽企业重金招聘Python工程师标准>>> 摘要: 原创出处 https://www.bysocket.com 「公众号&#xff1a;泥瓦匠BYSocket 」欢迎关注和转载&#xff0c;保留摘要&#xff0c;谢谢&#xff01; 02&#xff1a;WebFlux 快速入门实践 文章工程&#xff1a; JDK 1.8…

关于捕获键盘信息的processDialogkey方法

在一些控件里的keydown方法&#xff0c;没有办法捕获所有的按键消息 比如自己写一个窗体控件库&#xff0c;继承了UserControl 但是没有办法捕获一些键&#xff0c;比如方向键等 所以必须重载 processDialogkey 方法 processDialogkey 的描述 在msdn中是这样的 在消息预处理过程…

Visual Studio进行Web性能测试- Part III

原文作者&#xff1a;Ambily.raj 对于一个多用户的应用程序&#xff0c;性能是非常重要的。性能不仅是执行的速度&#xff0c;它包括负载和并发方面。Visual Studio是可以用于性能测试的工具之一。Visual Studio Test版或Visual Studio 2010旗舰版为自动化测试提供了支持。 介绍…

php mysql source_Mysql数据库导入命令Source详解

Mysql数据库导入命令Source详解几个常用用例&#xff1a;1.导出整个数据库mysqldump -u 用户名 -p 数据库名 > 导出的文件名mysqldump -u root -p dataname >dataname.sql这个时候会提示要你输入root用户名的密码,输入密码后dataname数据库就成功备份在mysql/bin/目录中.…

课堂练习(续)

源程序&#xff1a; Text_2.java import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileReader; import java.io.IOException; import java.io.InputStreamReader; import java.te…

任务二:1、选择器 2、连接集中状态的顺序 3、浮动的用发和原理 4、盒模型在IE和Google等不同浏览器的区别与联系...

1、选择器类型 标签选择器&#xff0c;类选择器&#xff0c;ID选择器&#xff0c;组合选择器&#xff0c;伪类和伪元素&#xff0c;属性选择器&#xff0c;子选择器&#xff0c;同胞选择器&#xff0c; :not()选择器 1、同胞选择器 相邻同胞标签&#xff1a; h2 p{ color:red…

struct发送与显示中文

中文的编码显示常常是一个让人头痛的问题&#xff0c;网络传输的时候中文也会变成二进制的流&#xff0c;接收方显示就成了一个大问题。 今天使用python的struct模块来对数据封包解包&#xff0c;同样有这个问题。解决方法是&#xff1a;一般会把python代码文件声明为utf-8编码…

mysql5.7.22密码设置_mysql5.7.22版本修改root密码

mysql5.6之前修改密码(字段password)mysql> use mysql;mysql> update user set passwordpassword(‘123‘) where user‘root‘ and host‘localhost‘;mysql> flush privileges;mysql 5.7.22版本修改密码(字段是authentication_string)mysql> use mysql;mysql>…

配置 php-fpm 监听的socket

一般现在我们配置的PHP的web环境&#xff0c;如LNMP&#xff08;linuxNginxMysqlPHP&#xff09;, 这里linux可能是centos, ubuntu..., 数据库可能是mysql, postgresql, sql server等。。 在服务器上安装PHP-FPM&#xff0c; nginx后&#xff0c; 我们要配置Nginx的http模块&am…

laravel基础课程---8、laravel响应和视图(响应是什么)

laravel基础课程---8、laravel响应和视图&#xff08;响应是什么&#xff09; 一、总结 一句话总结&#xff1a; 就是向请求返回的响应数据&#xff08;一般为html&#xff08;视图&#xff09;&#xff0c;当然也可以是变量值&#xff09;&#xff1a;所有的路由及控制器必须返…

ios应用内购买

参考&#xff1a; 1、http://troybrant.net/blog/2010/01/in-app-purchases-a-full-walkthrough/ 2、http://iosdeveloper.diandian.com/post/2011-08-26/4366441转载于:https://www.cnblogs.com/foxmin/archive/2012/09/08/2676580.html

mysql查询解析过程_MySQL查询执行过程详解

查询是用户通过设置某些查询条件&#xff0c;从表或其他查询中选取全部或者部分数据&#xff0c;以表的形式显示数据供用户浏览。查询是一个独立的、功能强大的、具有计算功能和条件检索功能的数据库对象。MySQL数据库中&#xff0c;MySQL查询同样是数据库的核心操作&#xff0…

.net erp(办公oa)开发平台架构之流程服务概要介绍

背景 搭建一个适合公司erp业务的开发平台。 架构概要图&#xff1a; 流程引擎开发平台&#xff1a; 包含流程引擎设计器&#xff0c;流程管理平台&#xff0c;流程引擎服务。目前只使用单个数据库进行管理。 流程引擎设计器 采用silverlight进行开发&#xff0c;本质是对流程…

数据分析-pca协方差

协方差是反映的变量之间的二阶统计特性&#xff0c;如果随机向量的不同分量之间的相关性很小&#xff0c;则所得的协方差矩阵几乎是一个对角矩阵。转载于:https://www.cnblogs.com/erweiyang/archive/2012/09/08/2676997.html