这篇文章主要讲解了“Python玩转SQL的神器有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python玩转SQL的神器有哪些”吧! 一般使用ORM框架,都会有一些初始化工作,比如数据库连接,定义基础映射等。以MySQL为例,创建数据库连接只需要传入DSN字符串即可。其中echo表示是否输出对应的sql语句,对调试比较有帮助。对于我个人而言,引进ORM框架时,我的项目会参考MVC模式做以下设计。其中model存储的是一些数据库模型,即数据库表映射的Python类;model_op存储的是每个模型对应的操作,即增删查改;调用方(如main.py)执行数据库操作时,只需要调用model_op层,并不用关心model层,从而实现解耦。举个栗子,如果我们有这样一张测试表在ORM框架中,映射的结果就是下文这个Python类首先,我们可以看到PyOrmModel继承了Base类,该类是sqlalchemy提供的一个基类,会对我们声明的Python类做一些检查,我将其放在base_model中。其次,每个Python类都必须包含__tablename__属性,不然无法找到对应的表。第三,关于数据表的创建有两种方式,第一种当然是手动在MySQL中创建,只要你的Python类定义没有问题,就可以正常操作;第二种是通过orm框架创建,比如下面:创建效果:第四,关于字段属性1.primary_key和autoincrement比较好理解,就是MySQL的主键和递增属性。2.如果是int类型,不需要指定长度,而如果是varchar类型,则必须指定。3.nullable对应的就是MySQL中的NULL 和 NOT NULL4.关于default和server_default: default代表的是ORM框架层面的默认值,即插入的时候如果该字段未赋值,则会使用我们定义的默认值;server_default代表的是数据库层面的默认值,即DDL语句中的default关键字。在SQLAl免费云主机域名chemy的文档中提到,数据库的增删查改是通过session来执行的。如上,我们可以看到,对于每一次操作,我们都需要对session进行获取,提交和释放。这样未免过于冗余和麻烦,所以我们一般会进行一层封装。1.采用上下文管理器的方式,处理session的异常回滚和关闭,这部分与所参考的文章是几乎一致的。2.在PyOrmModel中增加两个方法,用于model和dict之间的转换3.数据库操作的封装,与参考的文章不同,我是直接调用了session,从而使调用方不需要关注model层,减少耦合。4.调用方感谢各位的阅读,以上就是“Python玩转SQL的神器有哪些”的内容了,经过本文的学习后,相信大家对Python玩转SQL的神器有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是百云主机,小编将为大家推送更多相关知识点的文章,欢迎关注!
这篇文章主要讲解了“jquery跳转前如何设置cookie”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“jquery跳转前如何设置cookie”吧! 一、cookie简介首先,我们需要了解什么是cookie。c…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。