Python练习之ORM框架
短信预约 -IT技能 免费直播动态提醒
目的:
- 了解常用的ORM框架;
- 使用SQLObject框架操作MySQL数据库。
面试题:
- 在Python语言中有哪些常用的ORM框架,它们有什么区别?
- 如何使用SQLObject框架操作MySQL数据库?
一、Python语言中有哪些常用的ORM框架以及它们的区别
在Python语言中主要有以下两个常用的ORM框架:
- SQLAlchemy
- SQLObject
它们俩的区别:
- SQLAlchemy框架偏向于SQL,可以灵活地提交SQL语句;
- 而SQLObject框架更加面向对象,无法自由使用原生的SQL语句。
二、使用SQLObject框架操作MySQL数据库
第一题提到的两个框架都需要安装:
pip install sqlobject
1. 创建表
# coding=utf-8
from sqlobject import *
# 库名
mysql = 'mysql://root:123456@localhost:3306/test?charset=utf8'
# 用pymysql与sqlalchemy交互~
sqlhub.processConnection = connectionForURI(mysql, driver='pymysql')
class Person(SQLObject):
class sqlmeta:
table = 'new_persons'
name = StringCol(length = 30)
age = IntCol()
address = StringCol(length = 30)
salary = FloatCol()
# 习惯性创建一个新表之前先删除~ (是个好习惯哦!)
try:
Person.dropTable()
except:
pass
Person.createTable()
使用Navicat查看:
2. 插入数据
使用Navicat查看:
3. 修改数据
使用Navicat查看:
4. 查询数据
删除数据:
使用Navicat查看:
三、补充总结
首先,关于ORM简单聊几嘴:
对于像Python这样的面向对象的语言来说 ,一切皆对象 ,但是我们使用的数据库都是关系型的。 为了保证一致的使用习惯 ,我们就需要使用ORM在编程语言的对象模型和数据库的关系模型之间建立映射关系 ,这样我们在操作数据库时就可以直接使用编程语言的对象模型 ,而不用使用sql语言。
而ORM到底是什么呢?
- 英文全称object relational mapping(对象映射关系程序)
- 对象和关系之间的映射,让我们可以使用面向对象的方式来操作数据库。
- 把任何一个sql语句都封装成对象操作。关系模型和Python对象之间的映射如下:
table -> class | 表映射为类 |
row -> object | 行映射为实例 |
column -> property | 字段映射为属性 |
到此这篇关于Python练习之ORM框架的文章就介绍到这了,更多相关Python ORM框架内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341