sqlalchem表关联(一对多,一对一,多对多)
简介:
sqlalchemy是我们在python中经常使用的ORM组件,用来把python和数据库模型连接起来。
让用的关系型数据库,ms_sql_server , mysql,mariadb都是关系型数据库,那么我们一定要处理数据库之间的关系。
本文将探索使用sqlalchemy对数据库关系进行定义,并结合flask的开发,明确在flask-admin当中如何快速实现这种关系。
一:多对一
1.很多工人在一个班组,很多人拥有相同的学历。那么我们就要在工人这个页面单选所属班组,学历等级。
2.模型定义:
class Group(Base):
__tablename__ = 'group'
id = Column(Integer, primary_key=True)
users = relationship("Users", back_populates="group")
name = Column(String(32)) def __str__(self):
return self.name class Users(Base):
__tablename__ = 'users'
id = Column(Integer, primary_key=True)
group_id = Column(Integer, ForeignKey('group.id'))
group = relationship("Group", back_populates="users")
name = Column(String(32)) def __str__(self):
return self.name
3.测试:
在flask-admin当中管理Users表时,可以单选一个班组名称。
在flask-admin当中管理Group表时,可以多选用户。但是候选用户时所有用户,如果某个用户已经有一个所属班组,那么更新操作会覆盖这个用户之前的所属班组。
日常操作,一般时在用户页修改所属班组,极少在班组页面进行多选添加成员。而数据定义当中的Group.users,是方便进行双向连接,可以根据班组查询用户的。如果没有其它功能需要读取这个列表,那么可以取消这个定义。
如果需要这个操作,那么可以考虑在flask-admin中使用自定义视图的方式,不在创建,编辑表单中显示这个字段。
class Group_view(ModelView):
form_excluded_columns = ('users',)
admin.add_view(ModelView(Users, session, name='用户')) #系统默认视图注册
admin.add_view(Users_view(Users, session, name='用户')) #使用自定义视图注册。
二:多对多
1.每个班组都有工长,副工长。
2.模型定义:
group_duties = Table('group_duties', Base.metadata,
Column('group_id', Integer, ForeignKey('group.id')),
Column('duties_id', Integer, ForeignKey('duties.id'))
) class Group(Base):
__tablename__ = 'group'
id = Column(Integer, primary_key=True)
name = Column(String(32))
duties = relationship("Duties", secondary=group_duties) def __str__(self):
return self.name class Duties(Base):
__tablename__ = 'duties'
id = Column(Integer, primary_key=True)
name = Column(String(32))
group = relationship("Group", secondary=group_duties) def __str__(self):
return self.name class Duties_views(ModelView):
form_excluded_columns = ('group',)
3.测试
无论是班组表还是职务表,都可以进行多选。而且互相并不影响,但是实际使用中,一般是会对班组进行操作,对班组设置职务,而不是在职务选择班组,所以像多对一一样,我在表单隐藏了一项。
4.删除
当使用多对多关系时,我们同时使用了3张表,flask-admin只管理了两张表,第三张表作为中间表,当在flask-admin当中删除任意一项时,会自动处理中间表,删除中间表和该数据相关的条目。
三:一对一
1.我认为这个一对一是垂直分表来使用的东西。当数据口够大的时候,垂直分表,甚至分库,将是有效提升执行效率的办法。
2.源码:
class User(Base):
__tablename__ = 'user'
id = Column(Integer, primary_key=True)
name = Column(String(32))
ext = relationship("User_ext", uselist=False, back_populates="user") def __str__(self):
return self.name class User_ext(Base):
__tablename__ = 'user_ext'
id = Column(Integer, primary_key=True)
name = Column(String(32))
user_id = Column(Integer, ForeignKey('user.id'))
user = relationship("User", back_populates="ext") def __str__(self):
return self.name
3.实验:
主表或扩展表,都可以进行单选,选择另一个表的内容,但是和前面介绍的一样,最后一次操作,覆盖前期数据。
4.暂时真不知道怎么用,也不会实现垂直分表。继续查资料把。
四:
五:
六:
七:
八:
九:
十:
sqlalchem表关联(一对多,一对一,多对多)的更多相关文章
- Mybatis表关联一对多、多对一、多对多
项目工程结构如下: 1. 搭建MyBatis框架环境 首先需要引入两个包:mybatis.jar 和 sqljdbc42.jar包 若分页需要导入两个包:pagehelper-5.1.0.jar 和 ...
- 后盾网lavarel视频项目---lavarel多表关联一对多操作实例
后盾网lavarel视频项目---lavarel多表关联一对多操作实例 一.总结 一句话总结: 1.一对多中多那个部分的数据前端通过json弄到服务器 2.所有通过一操作多的时候,都要用上模型中定义的 ...
- 2.1、Hibernate多表操作--一对多、多对一、多对多。
一.什么是一对一.一对多.多对一及多对多关系(以简单的学生和老师的关系为例来说): 1.一对一:学生具有学号和姓名(假定没有同名的学生)这两个属性,那么我知道了学生的学号也就能找到对应的学生姓名,如果 ...
- Mybatis表关联一对多
有了前面几章的基础,对一些简单的应用是可以处理的,但在实际项目中,经常是关联表的查询,比如:最常见到的多对一,一对多等.这些查询是如何处理的呢,这一讲就讲这个问题.前面几篇教程中介绍的都是单表映射的一 ...
- django ORM模型表的一对多、多对多关系、万能双下划线查询
一.外键使用 在 MySQL 中,如果使用InnoDB引擎,则支持外键约束.(另一种常用的MyIsam引擎不支持外键) 定义外键的语法为fieldname=models.ForeignKey(to_c ...
- django(八)之数据库表的一对多,多对多表-增删改查
单表操作 表记录的添加 方式一: Book() b=Book(name="python基础",price=99,author="yuan",pub_date=& ...
- Hibernate关联关系配置(一对多,一对一,多对多)
一对多 创建两个类 Manager(一这一端) Worker(多这一端) 即一个经理下有多个员工 package com.hibernate.n21; import java.util.HashS ...
- 20.Yii2.0框架多表关联一对多查询之hasMany
目录 新手模式 hasMany关联模式查询 新建mode层Article.php 新建mode层Category.php 新建控制器HomeController.php 新手模式 用上次的查询结果,作 ...
- 21.Yii2.0框架多表关联一对多查询之性能优化--模型的使用
控制器里 功能: 通过分类,查分类下的所有文章 //关联查询 public function actionRelatesearch(){ //关联查询 //查询方法一(查一行) 一维数组下的值是obj ...
随机推荐
- mui体验理解
1. mui简介 1.1 缘起 1.基于jq的jqmobile,性能低的无法忍受,且UI难看 2.bootstrap这种响应式设计,性能在低端机不足,而且UI风格一看就是网页,不是App的 ...
- nodejs导出excel
//导出Excel var nodeExcel = require("excel-export"); var fs = require("fs"); var c ...
- 7.2内存管理-ARC
@0-简介 1编译器会自动在适当的地方插入适当的retain.release.autorelease语句 @1-ARC的判断原则 1只要还有一个强指针变量指向对象,对象就会保持在内存中 2强指针 ...
- 可访问范围 与 visual 或 abstract “修饰符”
protected:在当前类内定义,则在当前类“内部”可以调用,则在 派生子类"内部" 也可以调用 private,除去,在 派生子类"内部" 也可以调用,其它 ...
- 「SDOI2008」Sandy 的卡片
用第一个串建立后缀自动机.然后别的串在上面跑.从根节点开始.如果当前不能转移,一直移到slink或者根.如果移到根,能匹配长度变为0,否则变为maxlen[能转移的点]+1,再转移.转移完往slink ...
- SPL之Iterator和ArrayAccess的结合使用
<?php namespace TabControl; class MyIterator implements \Iterator, \ArrayAccess { private $data = ...
- CentOS6.8环境下搭建yum网络仓库
CentOS6.8环境下搭建yum网络仓库 本文利用ftp服务,在CentOS6.8系统下搭建一个yum仓库,然后用另一台虚拟机访问该仓库.并安装程序包 安装ftp服务 查询ftp服务是否安装 [ro ...
- bzoj3926: [Zjoi2015]诸神眷顾的幻想乡 后缀自动机在tire树上拓展
题意:有棵树每个点有个颜色(不超过10种),每个节点不超过20个儿子,问你每两点之间的颜色序列不同的有多少种 题解:先建出树,对于每个叶子节点,bfs一遍建在sam上,每次保留当前点在sam上的位置, ...
- bzoj3876: [Ahoi2014&Jsoi2014]支线剧情
题意:给一幅图,从1开始,每条边有边权最少走一遍,可以在任意点退出,问最小花费 题解:上下界费用流,每个边都流一遍,然后为了保证流量平衡,新建源点汇点,跑费用流把流量平衡 /************* ...
- loj#528. 「LibreOJ β Round #4」求和
求:\(\sum_{i=1}^n\sum_{j=1}^m\mu(gcd(i,j))^2\) 化简可得\(\sum_{i=1}^{min(n,m)}{\lfloor \frac{n}{i} \rfloo ...