sqlalchemy 的 ORM 方式使用示例

简介: 知乎: 使用 sqlalchemy 的 orm 方式操作数据库是一种怎样的体验? 答: 酸爽!   本文基于:win10 + python3.4 + sqlAlchemy 1.0.13 先看一个图(来源): 这是 sqlalchemy 的层级图。

知乎: 使用 sqlalchemy 的 orm 方式操作数据库是一种怎样的体验?

答: 酸爽!

 

本文基于:win10 + python3.4 + sqlAlchemy 1.0.13

先看一个图(来源):

这是 sqlalchemy 的层级图。不难发现,其中 orm 是最顶级的封装。

 

ORM 基本操作步骤如下:

1. 建立连接

from sqlalchemy import create_engine

engine = create_engine('sqlite:///:memory:', echo=True)

 

2. 建立会话

from sqlalchemy.orm import Session

session = Session(engine)

 

3. 声明基类

from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()

 

4. 定义表(继承基类)

from sqlalchemy import Column, Integer, ForeignKey
from sqlalchemy.orm import relationship

class Parent(Base):
    __tablename__ = 'parent'
    
    id = Column(Integer, primary_key=True)
    
    children = relationship("Child")
    
    def __repr__(self):
        return "<Parent(id='{}', children='{}')>".format(self.id, self.children)

class Child(Base):
    __tablename__ = 'child'
    
    id = Column(Integer, primary_key=True)
    parent_id = Column(Integer, ForeignKey('parent.id'))
    
    def __repr__(self):
        return "<Child(id='{}', parent_id='{}')>".format(self.id, self.parent_id)

 

5. 生成表

Base.metadata.drop_all(engine)
Base.metadata.create_all(engine) # 生产环境只需运行一次!!!!

 

6. 添加记录

session.add_all([Parent(children=[Child() for j in range(5)]) for i in range(2)])
session.commit()

 

7. 查询

# 懒加载 (lazyload)
# load everything, no eager loading.
for parent in session.query(Parent):
    print(parent.children)

# 联合加载 (joinedload)
# load everything, joined eager loading.
for parent in session.query(Parent).options(joinedload("children")):
    parent.children

# 子查询加载 (subqueryload)
# load everything, subquery eager loading.
for parent in session.query(Parent).options(subqueryload("children")):
    parent.children

 

8. 完整代码

from sqlalchemy import create_engine
from sqlalchemy.orm import Session
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, ForeignKey
from sqlalchemy.orm import relationship
from sqlalchemy.orm import joinedload, subqueryload


# 建立连接
engine = create_engine('sqlite:///:memory:', echo=True)


# 建立会话
session = Session(engine)


# 声明基类
Base = declarative_base()


# 定义表(继承基类)
class Parent(Base):
    __tablename__ = 'parent'
    
    id = Column(Integer, primary_key=True)
    
    children = relationship("Child")
    
    def __repr__(self):
        return "<Parent(id='{}', children='{}')>".format(self.id, self.children)

class Child(Base):
    __tablename__ = 'child'
    
    id = Column(Integer, primary_key=True)
    parent_id = Column(Integer, ForeignKey('parent.id'))
    
    def __repr__(self):
        return "<Child(id='{}', parent_id='{}')>".format(self.id, self.parent_id)
        

# 生成表
Base.metadata.drop_all(engine)
Base.metadata.create_all(engine) # 生产环境只需运行一次!!!!


# 添加记录
session.add_all([Parent(children=[Child() for j in range(5)]) for i in range(2)])
session.commit()


# 查询
# lazyload
# load everything, no eager loading.
for parent in session.query(Parent):
    print(parent.children)

# joinedload
# load everything, joined eager loading.
for parent in session.query(Parent).options(joinedload("children")):
    parent.children

# subqueryload
# load everything, subquery eager loading.
for parent in session.query(Parent).options(subqueryload("children")):
    parent.children

 

目录
相关文章
|
缓存 移动开发 关系型数据库
Linux 内存 占用较高问题排查
Linux 内存 占用较高问题排查
584 2
|
缓存 Java 开发工具
【开发工具】Gradle的安装 与 配置环境变量
【开发工具】Gradle的安装 与 配置环境变量
605 0
|
存储 数据库 计算机视觉
人脸识别流程
【7月更文挑战第30天】人脸识别流程。
855 3
解决CAS机制中ABA问题的AtomicStampedReference详解
AtomicStampedReference是一个带有时间戳的对象引用,能很好的解决CAS机制中的ABA问题,这篇文章将通过案例对其介绍分析。
474 0
解决CAS机制中ABA问题的AtomicStampedReference详解
|
Linux API 项目管理
Linux reset子系统及驱动实例
Linux reset子系统及驱动实例
|
机器学习/深度学习 编解码 计算机视觉
一文看尽深度学习中的各种数据增强(二)
一文看尽深度学习中的各种数据增强
928 0
|
前端开发
前端传递参数后端接收不到的坑
前端传递参数后端接收不到的坑
600 0
|
自然语言处理 监控 NoSQL
生产环境Redis连接,长时间无响应被服务器断开问题
生产环境Redis连接,长时间无响应被服务器断开问题
589 0
|
SQL JSON 中间件
超全API使用工具
如今,API已在软件、Web和移动应用程序开发领域无处不在,从企业内部到面向公众的应用以及与合作伙伴进行系统集成。通过使用API,开发人员可以创建满足各种客户需求的应用程序。而软件架构也在随着应用程序开发方法的改变而改变。