Python sqlalchemy orm 多对多外键关联
多对多外键关联
注:使用三张表进行对应关联
实现代码:
# 创建3个表 配置外键关联
# 调用Column创建字段 加类型
from sqlalchemy import Table, Column, Integer,String,DATE, ForeignKey # 调用操作链接,反查
from sqlalchemy.orm import relationship # 调用基类Base
from sqlalchemy.ext.declarative import declarative_base # 调用链接数据库
from sqlalchemy import create_engine # 会话
from sqlalchemy.orm import sessionmaker # 生成orm基类
Base = declarative_base() # 表3
# 表3做复合键,通过这种方式创建表 不需要对此表对应orm映射操作。
# 注:表2,表1,本身不知道表3的存在。
book_m2m_author = Table('book_m2m_author', Base.metadata, # 创建外键 关联books下的id
Column('book_id',Integer,ForeignKey('books.id')), # 创建外键 关联authors下的id
Column('author_id',Integer,ForeignKey('authors.id')),
) # 创建Book表2
class Book(Base):
__tablename__ = 'books' # 创建id字段 设置主键
id = Column(Integer,primary_key=True) # 创建name字段
name = Column(String(64)) # 创建日期字段
pub_date = Column(DATE) # Book通过Author 链接访问Auther表
# Book通过secondary=book_m2m_author 字段查看表3
# Author通过backref='books' 反查Book
authors = relationship('Author',secondary=book_m2m_author,backref='books') # 返回一个可以用来表示对象的可打印字符串
def __repr__(self):
return self.name # 创建Author表1
class Author(Base):
__tablename__ = 'authors' # 创建id字段 设置主键
id = Column(Integer, primary_key=True) # 创建name字段
name = Column(String(32)) # 返回一个可以用来表示对象的可打印字符串
def __repr__(self):
return self.name # encoding='utf-8' 链接字符集 ,echo=True 把所有信息打印出来
engine = create_engine("mysql+pymysql://root:123456@192.168.1.100/xiang",encoding='utf-8',
#echo=True
) #---------------1.创建表-----------------#
# 创建表结构
Base.metadata.create_all(engine)
#---------------------------------------#
#插入数据查看信息
from www import orm_m2m
# 会话
from sqlalchemy.orm import sessionmaker # bind=engine 绑定engine socket实例
Session_class = orm_m2m.sessionmaker(bind=orm_m2m.engine) # 生成session实例,如同pymysql内的cursor
Session = Session_class() #---------------2.写入数据-----------------# # Book添加书名与日期 数据
# b1 = orm_m2m.Book(name="learn python with kevin",pub_date="2018-05-01")
# b2 = orm_m2m.Book(name="learn zhangbillit whit kevin",pub_date="2018-05-02")
# b3 = orm_m2m.Book(name="Lear hook up girls with kevin",pub_date="2018-05-03") # Author 添加作者名
# a1 = orm_m2m.Author(name="kevin")
# a2 = orm_m2m.Author(name="Jack")
# a3 = orm_m2m.Author(name="Rain") # 通过authors外键 b1书 添加 a1,a3作者。
# b1.authors = [a1,a3]
# b3.authors = [a1,a2,a3] # 写如数据,写入顺序是随机的
# Session.add_all([b1,b2,b3,a1,a2,a3])
#---------------------------------------# #---------------3.查询数据-----------------# # 取出author表中 对象
author_obj = Session.query(orm_m2m.Author).filter(orm_m2m.Author.name=="kevin").first() # 通过作者取书的名字,books反向查找
print(author_obj.books) # 取出book表中 对象
book_obj = Session.query(orm_m2m.Book).filter(orm_m2m.Book.id==2).first() # 查看book表内对应书名字段id,的作者名称,authors查找
print(book_obj.authors) # 执行事务
Session.commit()
book_m2m_author
+---------+-----------+
| book_id | author_id |
+---------+-----------+
| 1 | 1 |
| 1 | 3 |
| 2 | 1 |
| 2 | 2 |
| 2 | 3 |
+---------+-----------+ books
+----+-------------------------------+------------+
| id | name | pub_date |
+----+-------------------------------+------------+
| 1 | learn python with kevin | 2018-05-01 |
| 2 | Lear hook up girls with kevin | 2018-05-03 |
| 3 | learn zhangbillit whit kevin | 2018-05-02 |
+----+-------------------------------+------------+ authors
+----+-------+
| id | name |
+----+-------+
| 1 | kevin |
| 2 | Jack |
| 3 | Rain |
+----+-------+
数据库测试
多对多删除
删除数据时不用管boo_m2m_authors , sqlalchemy会自动帮你把对应的数据删除
通过书删除作者
author_obj =s.query(Author).filter_by(name="Jack").first() book_obj = s.query(Book).filter_by(name="书名").first() # 从一本书里删除一个作者s.commit()
book_obj.authors.remove(author_obj)
直接删除作者
删除作者时,会把这个作者跟所有书的关联关系数据也自动删除
author_obj =s.query(Author).filter_by(name="kevin").first() # print(author_obj.name , author_obj.books) s.delete(author_obj) s.commit()
Python sqlalchemy orm 多对多外键关联的更多相关文章
- Python SQLAlchemy多对多外键关联时表结构
# 创建多对多表结构 from sqlalchemy.ext.declarative import declarative_base from sqlalchemy.engine import cre ...
- Python sqlalchemy orm 外键关联
创建外键关联 并通过relationship 互相调用 如图: 实现代码: import sqlalchemy # 调用链接数据库 from sqlalchemy import create_engi ...
- Python sqlalchemy orm 多外键关联
多外键关联 注:在两个表之间进行多外键链接 如图: 案例: # 创建两张表并添加外键主键 # 调用Column创建字段 加类型 from sqlalchemy import Integer, For ...
- pythonのsqlalchemy外键关联查询
#!/usr/bin/env python import sqlalchemy from sqlalchemy import create_engine from sqlalchemy.ext.dec ...
- 【Python】django模型models的外键关联使用
Python 2.7.10,django 1.8.6 外键关联:http://www.bubuko.com/infodetail-618303.html 字段属性:http://www.cnblogs ...
- Hibernate,关系映射的多对一单向关联、多对一双向关联、一对一主键关联、一对一外键关联、多对多关系关联
2018-11-10 22:27:02开始写 下图内容ORM.Hibernate介绍.hibername.cfg.xml结构: 下图内容hibernate映射文件结构介绍 下图内容hibernate ...
- sqlalchemy多外键关联
一.前言 如果有张表A的多个字段关联另一张表B的一个字段,就如同一个客户表的账单地址和发货地址,同时关联地址表中的id字段. 二.事例 # -*- coding: UTF-8 -*- from sql ...
- sqlalchemy外键关联
一.创建两张表,并关联外键 导入ForenginKey模块 # -*- coding: UTF-8 -*- from sqlalchemy import create_engine from sqla ...
- 测试脚本配置、ORM必知必会13条、双下划线查询、一对多外键关系、多对多外键关系、多表查询
测试脚本配置 ''' 当你只是想测试django中的某一个文件内容 那么你可以不用书写前后端交互的形式而是直接写一个测试脚本即可 脚本代码无论是写在应用下的test.py还是单独开设py文件都可以 ' ...
随机推荐
- winrar压缩过滤文件及文件夹
代码: .git .git\* .svn .svn\* .git~\* .git~ build\* build vsout\* vsout *.obj *.sdf *.opensdf game目录: ...
- python生成组织架构图(网络拓扑图、graph.editor拓扑图编辑器)
Graph.Editor是一款基于HTML5技术的拓补图编辑器,采用jquery插件的形式,是Qunee图形组件的扩展项目,旨在提供可供扩展的拓扑图编辑工具, 拓扑图展示.编辑.导出.保存等功能,此外 ...
- Tanya and Candies
Tanya and Candies time limit per test 1 second memory limit per test 256 megabytes input standard in ...
- 特殊字符url编码以后再解码后出现错误(¬ , ¢, ¤, £)
Url编码的原内容是 “¬ify_url=xxxx” 经过url编码以后再解码回来 “¬”的部分就变成了“¬” 解决方案:把原文里面待url编码的&符号先替换成 ...
- CString中 format、trimLeft和trimright、trim 和FindOneOf用法
1.format 可以帮助各种类型转换成CString. a. int 转 CString CString str; int number = 4; str.Format(_T("%d&qu ...
- juqery 给本身的class加上一个class 或也可以实现关注商品,取消关注商品
$("#goods1").on("click",".ICON-fen-LOVE",function(){ var $this = $(thi ...
- HTML、CSS知识点,面试开发都会需要--No.4 内容布局
No.4 内容布局 1.列举场景 同一行布局三个元素.三个元素等比显示,并且其他元素不会围绕这三个元素.如下要让下面的三个column等比显示在一行: 2.通过Float属性实现 (1)float:l ...
- C++的一些知识
1.C++中非虚函数都是静态绑定,虚函数是动态绑定.指针或引用访问对象的虚函数时才能进行动态绑定. 静态多态性:编译时确定操作的对象.如:函数重载,运算符重载. 动态多态性:运行时确定操作的对象. 绑 ...
- yum安装openjdk
含有的命令:yum,java -version,javac,source,vim [root@ycj ~]# yum -y install java-1.8.0-openjdk-devel //安装j ...
- 选择结构的三角关系Switch、Case、Default!!!
选择结构的三角关系Switch.Case.Default!!! 今天我们学习选择结构进化章节——Switch结构,他与if有什么区别呢? 相同点: 都是用来处理多分支条件的结构 不同点: switch ...