当前位置: 首页 > news >正文

python sqlalchemy(ORM)- 02 表关系

文章目录

  • 表关系
  • ORM表示 1v1
  • ORM表示 1vm

表关系

  • 1:1,表A 中的一条记录,仅对应表B中的一条记录;表B的一条记录,仅对应表A的一条记录。
  • 1:m,表A中的一条记录,对应表B中的多条记录,表B中的一条记录,仅对应表A的中的一条;(多的一方创建外键)
  • m:n ,表A 中的一条记录,可对应表B中的多条记录;表B的一条记录,也可对应表A的多条记录。

 

ORM表示 1v1

pass

 

ORM表示 1vm

  • 表结构
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  • 创建模型类
from sqlalchemy import Column, Integer, Float, String, Enum, ForeignKey, VARCHAR
from sqlalchemy.dialects.mysql import VARCHAR
from sqlalchemy.orm import declarative_base, relationship, Session, sessionmaker # sessionmaker返回一个会话类
from sqlalchemy import create_engine# base class
Base = declarative_base()# Address
class Address(Base):__tablename__ = "address_t"id = Column(Integer, primary_key=True)# 地址字段, mysql数据库使用VARCHAR类型,其他使用String类型title = Column("address", String(50).with_variant(VARCHAR(50, charset="utf8"), "mysql"), nullable=False)# 外键user_id = Column(Integer, ForeignKey("user_t.id"), nullable=True)# 关系(非表字段),模型类之间的引用# back_populates 双向的 反向引用(通过属性)# cascade 级联动作 delete-orphan 表示子表断开引用主表时,删除记录,仅用于1:m 中1的一方user = relationship("User", back_populates="addresses")def __repr__(self): # 打印对象时的输出return f"{self.title}"# User
class User(Base):__tablename__ = "user_t"id = Column(Integer, primary_key=True)name = Column(String(30), unique=True)fullname = Column(String(50))# 枚举sex = Column(Enum("male", "female", name="sex")) age = Column(Integer)role_id = Column(Integer, ForeignKey("role_t.id"), nullable=True)# 关系addresses = relationship("Address", back_populates="user", cascade="all, delete-orphan")role = relationship("Role", back_populates="users")def __repr__(self):return f"{self.name}"# Role
class Role(Base):__tablename__ = "role_t"id = Column(Integer, primary_key=True)name = Column(String(30), unique=True)# 关系users = relationship("User", back_populates="role")def __repr__(self):return f"{self.name!r}"# 创建懒连接
sqlalchemy_database_uri = "postgresql://user:pw@ip:port/dbxx"
engine = create_engine(sqlalchemy_database_uri, echo=True)
# 删除所有的表
Base.metadata.drop_all(engine)
# 创建所有的表
Base.metadata.create_all(engine)
# 创建会话
with Session(engine) as session:jack = User(name="jack", fullname="张三", sex="male", age=34, addresses=[Address(title="北京"), Address(title="河南")])tom = User(name="tom", fullname="李四", sex="female", age=25, addresses=[Address(title="武汉")])# 创建角色 role = Role(name="老师", users=[jack, tom])# 仅仅添加一个****主表记录**** 即可,子表记录 连带添加session.add(role)session.commit() # 事务的最终提交

在这里插入图片描述
在这里插入图片描述
主表记录插入时,连带子表记录一起插入。

http://www.lryc.cn/news/204694.html

相关文章:

  • Http长连接同一个socket多个请求和响应如何保证一一对应?
  • Standford Compiler Course Assignment 2
  • 基于Java的校园论坛管理系统设计与实现(源码+lw+部署文档+讲解等)
  • 谈谈你对Spring的理解
  • 系统架构师考试易混淆知识点总结
  • 反射的作用( 越过泛型检查 和 可以使用反射保存所有对象的具体信息 )
  • 前端开发实践:vue中用qrcode库将超链接生成二维码图片
  • 数据库连接池有什么用?它有哪些关键参数?
  • Android Settings解析
  • Spring+spring mvc+mybatis整合的框架
  • 02-2、PyCharm中文乱码的三处解决方法
  • Axi接口的DDR3:参数,时序,握手机制
  • 浏览器标签上添加icon图标;html引用ico文件
  • 深入解析i++和++i的区别及性能影响
  • 2023年中国酒类新零售行业发展概况分析:线上线下渠道趋向深度融合[图]
  • 交通 | 实现可泛化性:机器学习求解VRP
  • php使用sqlServer
  • H3C SecParh堡垒机 get_detail_view.php 任意用户登录漏洞
  • python爬虫涨姿势板块
  • 软件设计原则-里氏替换原则讲解以及代码示例
  • Sui提供dApp Kit 助力快速构建React Apps和dApps
  • 2023年系统设计面试如何破解?进入 FAANG 面试的实战指南
  • (react+ts)vite项目中的路径别名的配置
  • 【MATLAB源码-第51期】基于matlab的粒子群算法(PSO)的栅格地图路径规划。
  • React之render
  • 基于springboot实现财务管理系统项目【项目源码+论文说明】计算机毕业设计
  • 设计模式:组合模式(C#、JAVA、JavaScript、C++、Python、Go、PHP)
  • 超强满血不收费的AI绘图教程来了(在线Stable Diffusion一键即用)
  • 【蓝桥每日一题]-动态规划 (保姆级教程 篇12)#照相排列
  • 纺织工厂数字孪生3D可视化管理平台,推动纺织产业数字化转型