python SQLAlchemy的Mapping与Declarative详解


Posted in Python onJuly 04, 2019

前面介绍过vSQLAlchemy中的 Engine 和 Connection,这两个对象用在row SQL (原生的sql语句)上操作,而 ORM(Object Relational Mapper)则是一种用面向对象的思维来操作表数据的技术。所谓ORM 就是Python 对象到数据表的一种映射关系。

以前 SQLAlchemy 是怎么把Python对象和数据库中表里面的每条记录进行映射的呢?通过一个mapping函数

先来看个例子:

from sqlalchemy import Table, MetaData, Column, Integer, String,
from sqlalchemy.orm import mapper

# 数据库的元数据,你可以认为它是一个容器,装载了所有的表结构
metadata = MetaData()

# 数据库中的news_article表
article = Table("news_article", metadata,
        Column("id", Integer, primary_key=True),
        Column("title", String)
        )

# 这是一个普通的Article类
class Article:
  def __init__(self, title):
    self.title = title

# 通过mapper函数进行映射关联
mapper(Article, article)

关联后怎么使用呢?看例子:

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind=engine)
session = Session()
# 通过Artcile类来查询id==4554的记录,这完全是用面向对象的方式执行sql了
# 返回结果就是Article的实例对象
result = session.query(Article).filter(Article.id==4554).first()
print(result.id) # 4554
print(result.title) # xxxxxxxxx

mapper 函数进行映射后,通过query查询返回的结果,会自动将返回结果构造成一个Article对象,并拥有了id 属性,这就是ORM的魔力所在。

而新的ORM映射不需要手动通过mapping函数来关联table与类之间的关系,可以直接通过声明(Declarative )系统(我不知道这样翻译对不对)来定义一个类,这个类会直接映射到数据库的表,declarative 把 Table、mapper、还有类这三者放在一块进行声明,从而实现了ORM的映射。来看例子:

from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()

class Article(Base):
  __tablename__ = 'news_article'
  id = Column(Integer, primary_key=True)
  title = Column(String(50))

是不是简单很多了,没有了Table的定义,没有mapper函数,只有一个类的定义,这个类必须继承基类 Base,Base 就是我们的声明系统,这样就完成了Table与类之间的映射关系,而背后的操作都是通过一个declarative_base 工厂方法构造的声明系统完成的。

我们把 Article 又称之为映射类,这个类持有 Table 和 mapper 函数的引用。

>>> print(Article.__table__)
news_article

>>>print(Article.__mapper__)
Mapper|Article|news_article

# 前面将的metadata 可以通过 Base 获取
>>>print(Base.metadata)
MetaData(bind=None)

MetaData 有什么用的?可以通过它来创建表或者删除表。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
跟老齐学Python之集合(set)
Sep 24 Python
python实现一次创建多级目录的方法
May 15 Python
简单讲解Python编程中namedtuple类的用法
Jun 21 Python
python中使用PIL制作并验证图片验证码
Mar 15 Python
python进行文件对比的方法
Dec 24 Python
python+openCV利用摄像头实现人员活动检测
Jun 22 Python
Python学习笔记之Break和Continue用法分析
Aug 14 Python
pytorch制作自己的LMDB数据操作示例
Dec 18 Python
使用python实现多维数据降维操作
Feb 24 Python
Python 实现将大图切片成小图,将小图组合成大图的例子
Mar 14 Python
Python绘制全球疫情变化地图的实例代码
Apr 20 Python
python3:excel操作之读取数据并返回字典 + 写入的案例
Sep 01 Python
pandas分区间,算频率的实例
Jul 04 #Python
Django中信号signals的简单使用方法
Jul 04 #Python
python3读取图片并灰度化图片的四种方法(OpenCV、PIL.Image、TensorFlow方法)总结
Jul 04 #Python
pybind11和numpy进行交互的方法
Jul 04 #Python
pandas计算最大连续间隔的方法
Jul 04 #Python
python SQLAlchemy 中的Engine详解
Jul 04 #Python
Python Pandas实现数据分组求平均值并填充nan的示例
Jul 04 #Python
You might like
新手学PHP之数据库操作详解及乱码解决!
2007/01/02 PHP
php实现信用卡校验位算法THE LUHN MOD-10示例
2014/05/07 PHP
Linux+Nginx+MySQL下配置论坛程序Discuz的基本教程
2015/12/23 PHP
php微信开发之带参数二维码的使用
2016/08/03 PHP
Javascript 生成指定范围数值随机数
2009/01/09 Javascript
jquery-easyui关闭tab自动切换到前一个tab
2010/07/29 Javascript
qTip 基于JQuery的Tooltip插件[兼容性好]
2010/09/01 Javascript
IE的事件传递-event.cancelBubble示例介绍
2014/01/12 Javascript
jQuery中的$.ajax()方法应用
2014/05/06 Javascript
jquery实现类似EasyUI的页面布局可改变左右的宽度
2020/09/12 Javascript
在JavaScript中构建ArrayList示例代码
2014/09/17 Javascript
全面解析多种Bootstrap图片轮播效果
2016/05/27 Javascript
在js代码拼接dom对象到页面上去的模板总结(必看)
2017/02/14 Javascript
JS扩展String.prototype.format字符串拼接的功能
2018/03/09 Javascript
浅析Vue 生命周期
2018/06/21 Javascript
vue elementui form表单验证的实现
2018/11/11 Javascript
jQuery zTree树插件的使用教程
2019/08/16 jQuery
js实现详情页放大镜效果
2020/10/28 Javascript
Pyramid添加Middleware的方法实例
2013/11/27 Python
利用Python如何生成便签图片详解
2018/07/09 Python
python全栈知识点总结
2019/07/01 Python
tensorflow实现打印ckpt模型保存下的变量名称及变量值
2020/01/04 Python
Python pip install如何修改默认下载路径
2020/04/29 Python
HTML最新标准HTML5总结(必看)
2016/06/13 HTML / CSS
Boda Skins皮衣官网:奢侈皮夹克,全球配送
2016/12/15 全球购物
欧洲领先的火车票和大巴票预订平台:Trainline
2018/12/26 全球购物
安全的后院和健身蹦床:JumpSport
2019/07/15 全球购物
Herschel Supply Co.美国:背包、手提袋及配件
2020/11/24 全球购物
数据库方面面试题
2012/04/22 面试题
会计系中文个人求职信
2013/12/24 职场文书
工作表现评语
2014/01/19 职场文书
网上快餐厅创业计划书
2014/02/01 职场文书
团队口号大全
2014/06/06 职场文书
英语系毕业生求职信
2014/07/13 职场文书
中小企业员工手册范本
2015/05/14 职场文书
Python OpenCV实现传统图片格式与base64转换
2021/06/13 Python