Sqlautocode是SQLAlchemy一个数据库映射工具,可以将数据库文件映射为python代码,直接在程序中移植使用。最近在使用过程中遇到了一些坑,通过用代码编辑工具pycharm阅读源码和多方查找技术论坛如SegmentFault和StackOverflow,通过系列的代码追踪和分析,最终解决了一些关于Sqlautocode在实用上的版本冲突问题。现在说说我在使用中遇到的坑,作为分享,希望对读者有用。

我使用的是Linux操作系统,其他操作系统可能不会出现以下的一些问题。

为了更好地说明坑是怎么来的。首先讲讲Sqlautocode的简单用法:

pip install  sqlautocode

安装好了sqlautocode包后在终端输入:

sqlautocode mysql://'root':'XXX'@127.0.0.1:3306/dbname  -t Goods  -o goods-test.py

就可以将所想要导出的数据表导出为py文件

这条命令中的数据库地址  ‘ mysql://'root':'XXX'@127.0.0.1:3306/dbname ’ 与我们平常在程序中写的数据库地址没有什么区别。dbname就是我们要导出的数据库,Goods就是数据库里面的一张表(这是我之前创建好的一张表),goods-test.py就是我导出的py文件名(不需要事先创建,命令执行过程会自动创建)。注意:-t  -o 一定要有,这是命令的参数,分别表示的含义是table(数据表),output(输出)

在Linux系统终端输入上面的命令后,在调试的过程,出现了以下三个问题

错误1:

except sqlalchemy.exceptions.SQLAlchemyError, ex:
AttributeError: 'module' object has no attribute 'exceptions'

解决思路:

阅读错误信息可以看到,'module' object has no attribute 'exceptions'

什么意思?翻译过来就是模块对象没有一个叫‘exceptions’的属性,也就是说,sqlalchemy没有这个exceptions类!

那究竟如何解决这个问题?在pycharm(再一次点赞pycharm,在阅读源码方面真的很方便)中点击开sqlalchemy的源码,用ctrl+F可以定位查找我们需要查找的内容,输入'exc'会发现得到了定位,原来新版sqlalchemy用的是exc模块下的SQLAchemyError

用pycharm寻找源码的出处,对exceptions进行更改,改为sqlachemy.exc.SQLAlchemyError

错误2:

no mysqldb

我通过查找StackOverflow上的文章解决的,解决方案可以参考地址:

https://stackoverflow.com/questions/2952187/getting-error-loading-mysqldb-module-no-module-named-mysqldb-have-tried-pre

注意:通常出现错误原因是sqlalchemy0.7(最新版本)和python2.7(旧版本)间的冲突,体现在一些代码的书写上的不同(实际是引用类的不同)

错误3:

在运行命令

sqlautocode mysql://'root':'XXX'@127.0.0.1:3306/dbname  -t Goods  -o goods-test.py

时总是报出以下错误:

解决思路:

在StackOverflow上搜寻无果,决定自己根据错误信息一步步地进行分析

首先用pycharm打开sqlautocode的_ _init_ _.py文件,

找到reflection_schema = db.dialect.default_schema_name  这句代码,

再用ctrl+鼠标左键,发现是无法进行跳转到相应源码的函数位置,所以推测是sqlachemy版本升级之后与python2.7源码不匹配,需要对sqlchemy源码进行一些修改。

接下来是ctrl+鼠标左键,点击dialect跳转到源码位置,发现以下

显然,db.dialect在获取默认表名的时候是用dialect.default_schema_name属性来获取的,而不是用函数get_default_schema_name()

同时sqlalchemy源码中tablenames = db.dialect.table_names(conn, reflection_schema)一行实际上调用的是

tablenames = db.dialect.get_table_names(conn, reflection_schema)

即table_names()应该换为get_taable_names()方法。

进行以上修改之后再在终端输入命令

sqlautocode mysql://'root':'XXX'@127.0.0.1:3306/dbname  -t Goods  -o goods-test.py

就可以获取到表格的ORM映射.py文件

好了,上面3个问题轻松解决了,关于为什么是这样解决的,这就要涉及到源码版本问题和源码的一些行文逻辑问题了,要深究下来会有很多东西要讲,我自己目前对sqlautocode这款工具的源码还没完全理解透彻,就不在这里班门弄斧了。有兴趣的读者可以用pycharm自己去研究研究。

Sqlautocode使用过程的一些坑的更多相关文章

  1. 表结构中updated_time设计为ON UPDATE CURRENT_TIMESTAMP时,使用过程的一个坑

    一.mysql表结构中存在如下设计时 表结构中updated_time设计为ON UPDATE CURRENT_TIMESTAMP时,如下 `updated_time` datetime NOT NU ...

  2. flutter 安装过程遇到的坑

    Flutter是一个移动应用程序的软件开发工具包(SDK),用一个代码库构建高性能.高保真的iOS和Android应用程序.目标是使开发人员能够为Android和iOS提供自然的高质量的应用,在滚动行 ...

  3. Torch-RNN运行过程中的坑 [2](Lua的string sub函数,读取中文失败,乱码?)

    0.踩坑背景 仍然是torch-rnn/LanguageModel.lua文件中的一些问题,仍然是这个狗血的LM:encode_string函数: function LM:encode_string( ...

  4. Torch-RNN运行过程中的坑 [1](读取Lua非空table,size为0)

    0.踩坑背景 执行Torch-RNN的时候,在LanguageModel.lua中的encode_string函数中,对start_text的各个character进行id映射编码,实现功能类似“北京 ...

  5. Torch-RNN运行过程中的坑 [0](一些基础概念)

    0.Lua & LuaJIT简介 Lua 是一种轻量小巧的脚本语言,用标准C语言编写并以源代码形式开放, 其设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能. Lua 是巴 ...

  6. 菜鸟帮你跳过openstack配置过程中的坑

    一:前言 对于一个以前做java全栈工程师而言,而且没学过Linux,很少用虚拟机(还是在大学的时候简单的用过),去配置openstack我想我入的坑肯定比有基础的一定要多,躺在每个坑中徘徊思索的时间 ...

  7. 菜鸟帮你跳过openstack配置过程中的坑[文末新添加福利]

    一:前言 对于一个以前做java全栈工程师而言,而且没学过Linux,很少用虚拟机(还是在大学的时候简单的用过),去配置openstack我想我入的坑肯定比有基础的一定要多,躺在每个坑中徘徊思索的时间 ...

  8. Vue发布过程中遇到坑,以及webpack打包优化

    前言 这段时间,本人自己做了一个vue画面部署到自己的服务器上,发现运行速度慢的的惊人,虽然服务器很渣(本人没什么钱,只能租最差的服务器,主要是给自己学习用的),但是这样开发出来的网站简直不能用,所以 ...

  9. 学习django3过程中的坑

    最近跟着Django by Example 2015学习,可老想用最新版的Django3.在学的过程中可踩了不少坑. 今天就又碰到一个: 在这本书中96页有这样的代码: url(r'^login/$' ...

随机推荐

  1. 小鬼难缠--python小bug备忘

    今天编译pyhon做人脸识别,遇到几个问题,做个记录吧. 编译报错: File "harrClassifier.py", line 17, in <module> fl ...

  2. Spring Boot读取配置的 5 种方式

    读取application文件 在application.yml或者properties文件中添加: info.address=USA info.company=Spring info.degree= ...

  3. HoloLens开发手记 - 使用Windows设备控制台 Using Windows Device Portal

    Windows设备控制台允许你通过Wi-Fi或USB来远程控制你的HoloLens设备.设备控制台是HoloLens上的一个Web Server,你可以通过PC的浏览器来连接到它.设备控制台包含了很多 ...

  4. jsp和servlet的关系

    JSP是Servlet技术的扩展,本质上就是Servlet的简易方式.JSP编译后是“类servlet”. Servlet和JSP最主要的不同点在于:Servlet的应用逻辑是在Java文件中,并且完 ...

  5. Servlet-xml配置简介以及url-pattern简介

    编写一个Servlet是需要实现Servlet接口,或者继承HttpServlet. 一个已经注册的Servlet可以被多次映射,如下图所示 或者多个url-pattern放在同一个servlet-m ...

  6. python异步编程--回调模型(selectors模块)

    目录 0. 参考地址 1. 前言 2. 核心类 3. SelectSelector核心函数代码分析 3.1 注册 3.2 注销 3.3 查询 4. 别名 5. 总结 6. 代码报错问题 1. 文件描述 ...

  7. 自动化测试工具selenium webdirver

    看视频学到的,自动化测试工具,可以模拟用户操作,包括输入,点击等操作 新建新文件夹 在命令行执行npm init  ,一路回车,把项目先初始化 安装  npm install selenium-web ...

  8. Android使用AIDL跨进程通信

    一.基本类型 1.AIDL是什么 AIDL是Android中IPC(Inter-Process Communication)方式中的一种,AIDL是Android Interface definiti ...

  9. Java与c#的一些细节区别

    实习中用的语言是c#,第一次接触到这种语言,然后写的过程中,发觉和Java几乎一摸一样,好像根本是无缝切换,但细节仍有很大的区别,称有空总结一波里面的部分细节实现. ps. 我写c#过程中,发觉c#有 ...

  10. JavaScript之八皇后问题(递归)

      八皇后问题,是一个古老而著名的问题,该问题最早由国际西洋棋棋手马克斯·贝瑟尔(Max Bezzel)于1848年提出.八皇后问题的具体描述为:在\(8\times8\)的国际象棋上摆放8个皇后,使 ...