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自己去研究研究。

最新文章

  1. MVVM架构~目录
  2. MVC数据传递和多表单
  3. Scalaz(47)- scalaz-stream: 深入了解-Source
  4. jQuery动态加载脚本 $.getScript();
  5. html--整站制作
  6. PHP和AJAX笔记汇总
  7. WaitForSingleObject与WaitForMultipleObjects用法详解(好用,而且进入一个非常高效沉睡状态,只占用极少的CPU时间片)
  8. easy_install和pip区别
  9. 开通博客第一天 (先发一些android(java)常见异常信息
  10. Eclipse开发Maven项目提示:程序包org.junit不存在解决方案
  11. Python数据结构之三——dict(字典)
  12. 【BZOJ1087】【SCOI2005】互不侵犯(状态压缩,动态规划)
  13. 类设计:设计卖车的4S店
  14. java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or.....
  15. 将Windows下的InfluxDB、Grafana做成Windows服务
  16. kubernetes-PetSet
  17. ASP.NET中使用JSON方便实现前台与后台的数据交换
  18. linux中如何通过echo输出!(叹号)? -bash: !": event not found
  19. Flask初级(八)flash与前台交互get post 简介
  20. 常用帝国cms标签收录

热门文章

  1. Java中的引用传递和值传递
  2. python 中numpy中函数hstack用法和作用
  3. RabbitMQ常见错误1
  4. 第三章:Activity的生命周期
  5. webpack-loader是怎样炼成的
  6. python 装饰方法
  7. Java并发编程笔记之 CountDownLatch闭锁的源码分析
  8. C/C++ 中嵌入 arm 汇编
  9. CS231n官方笔记授权翻译总集篇发布
  10. 微信公众平台.net HttpClient 异步客户端