1. # 角色表模型
    class Role(db.Model):
    r_id = db.Column(db.Integer, primary_key=True)
    r_name = db.Column(db.String(10))
    __tablename__ = 'role'
  2.  
  3. # 角色表和权限表的中间表
    # r_p为关联表的表名
    r_p = db.Table('r_p',
    db.Column('role_id',db.Integer,db.ForeignKey('role.r_id'),primary_key=True),
    db.Column('permission_id', db.Integer, db.ForeignKey('permission.p_id'),primary_key=True)
    )
  4.  
  5. # 权限表模型
    class Permission(db.Model):
    p_id = db.Column(db.Integer, autoincrement=True, primary_key=True)
    p_name = db.Column(db.String(16), unique=True)
    p_er = db.Column(db.String(16), unique=True)
      # 添加多对多的反向引用,必须用secondary指定中间关联表
      # 用权限查询角色时用查询到的权限对象:“权限对象.roles.all()”得到其对应的所有角色
    roles =db.relationship('Role', secondary = r_p, backref = db.backref('permission', lazy = True))
    __tablename__ = 'permission'
      # db.backref('permission', 中的permission用来反向关联,用角色查询其对应的所有权限。用查询到的 '角色对象.permission.all()'得到。
    # relationship可以放到任意一个类中都行,与之相反。
  1. views视图函数:
  1. # 多对多查询
  2.  
  3. @user.route('/userperlist/', methods=['GET', 'POST'])
  4. @is_login
  5. def userperlist():
  6.   # 首先获得主表角色的ID
  7. r_id = request.args.get('r_id')
  8.   # 使用ID来获取该角色对象
  9. roles = Role.query.get(r_id)
  10. # 然后通过角色,找权限
  11. pers = roles.permission
  12.  
  13. #多对多添加
  14. # 权限管理/角色列表/添加权限
  15. @user.route('/adduserper/', methods=['GET', 'POST'])
  16. @is_login
  17. def adduserper():
  18. r_id = request.args.get('r_id')
  19. permissions = Permission.query.all()
  20. if request.method == 'GET':
  21. return render_template('add_user_per.html',permissions = permissions)
  22. if request.method == 'POST':
  23. p_id = request.form['p_id']
  24.      # 找出对应权限
  25.      # 此处用get(id)获取, 不要使用filter_by
  26.     # 对多关系中获取对象,只能用get(id)方法,不能通过filter或者filter_by来获取
  27. permission = Permission.query.get(p_id)
  28.      # 找出对应角色
  29. role = Role.query.get(r_id)
  30.      # 然后添加权限
  31. role.permission.append(permission)
  32.      # 保存数据库
  33. db.session.commit()
  34. return redirect(url_for('user.roles'))
  35.  
  36. #多对多删除
  37. # 权限管理/角色列表/减少权限
  38. @user.route('/subuserper/', methods=['GET', 'POST'])
  39. @is_login
  40. def subuserper():
  41. r_id = request.args.get('r_id')
  42. roles = Role.query.get(r_id)
  43. pers = roles.permission
  44. if request.method == 'GET':
  45. return render_template('user_per_list.html',pers=pers)
  46. if request.method == 'POST':
  47. p_id = request.form['p_id']
  48. permission = Permission.query.get(p_id)
  49. role = Role.query.get(r_id)
  50.     # 和添加一样,只是此处用的是remove()
  51. role.permission.remove(permission)
  52. db.session.commit()
  53. return redirect(url_for('user.roles'))
  1. 总结:ORM操作时,多对多关系的角色权限表(中间关联表),不需要用户维护.
  1.  

flask中 多对多的关系 主从表之间的的增删改查的更多相关文章

  1. Django项目的创建与介绍.应用的创建与介绍.启动项目.pycharm创建启动项目.生命周期.三件套.静态文件.请求及数据.配置Mysql完成数据迁移.单表ORM记录的增删改查

    一.Django项目的创建与介绍 ''' 安装Django #在cmd中输入pip3 #出现这个错误Fatal error in launcher: Unable to create process ...

  2. mysql对库,表及记录的增删改查

    破解密码 #1.关闭mysqlnet stop mysqlmysql还在运行时需要输入命令关闭,也可以手动去服务关闭 #2.重新启动mysqld --skip-grant-tables跳过权限 #3m ...

  3. 第三百零七节,Django框架,models.py模块,数据库操作——表类容的增删改查

    Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...

  4. 五 Django框架,models.py模块,数据库操作——表类容的增删改查

    Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...

  5. Oracle学习总结_day01_day02_表的创建_增删改查_约束

    本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! 更新: SELECT * FROM (SELECT R ...

  6. Java代码自动生成,生成前端vue+后端controller、service、dao代码,根据表名自动生成增删改查功能

    本项目地址:https://github.com/OceanBBBBbb/ocean-code-generator 项目简介 ocean-code-generator采用(适用):     ,并使用m ...

  7. 表结构修改以及sql增删改查

    修改表结构 修改表名 alter table 表名 rename 新名 增加字段 alter table 表名 add 字段名 数据类型 约束 删除字段 alter table 表名 drop 字段名 ...

  8. 如何搭建一个WEB服务器项目(二)—— 对数据库表进行基本的增删改查操作

    使用HibernateTemplate进行增删改查操作 观前提示:本系列文章有关服务器以及后端程序这些概念,我写的全是自己的理解,并不一定正确,希望不要误人子弟.欢迎各位大佬来评论区提出问题或者是指出 ...

  9. 数据库中的记录通过servlet回显到jsp页面中(连接数据库或者查询參照:对数据进行增删改查)

    我们常常会用到通过图书的名称来查询图书那么这种话我们也就会使用到从数据库中搜索出数据而且载入到自己的Jsp页面中 这种话我们须要将从数据库中获取到的数据放进响应中然后通过%=request.getAt ...

随机推荐

  1. Dart的JIT 与 AOT

    JIT:Just In Time AOT:Ahead of Time 含义: 目前,程序主要有两种运行方式:静态编译与动态解释. 静态编译的程序在执行前全部被翻译为机器码,通常将这种类型称为AOT ( ...

  2. 带你封装自己的MVP+Retrofit+RxJava2框架(一)

    前言 文本已经收录到我的Github个人博客,欢迎大佬们光临寒舍:我的GIthub博客 看完本篇文章的,可以看下带你封装自己的MVP+Retrofit+RxJava2框架(二),里面封装得到了改进 本 ...

  3. TCP/IP协议族的四个层次

    OSI7层模型的小结 : 在7层模型中,每一层都提供一个特殊的网络功能.从网络功能的角度看:下面4层(物理层.数据链路层.网络层和传输层)主要提供数据传输和交换功能,即以节点到节点之间的通信为主:第4 ...

  4. 用 Java 实现人脸识别功能(附源码)

    整理了一些Java方面的架构.面试资料(微服务.集群.分布式.中间件等),有需要的小伙伴可以关注公众号[程序员内点事],无套路自行领取 更多优选 一口气说出 9种 分布式ID生成方式,面试官有点懵了 ...

  5. Python3爬虫使用requests爬取lol英雄皮肤

    本人博客:https://xiaoxiablogs.top 此次爬取lol英雄皮肤一共有两个版本,分别是多线程版本和非多线程版本. 多线程版本 # !/usr/bin/env python # -*- ...

  6. Flutter的盒子约束

    由Expanded widget引发的思考 设计稿如下 布局widget分解 很常见的一种布局方式:Column的子widget中包含ListView @override Widget build(B ...

  7. 基于VR技术的输电线路巡检仿真系统

    基于VR技术,搭建电力输电仿真系统用于培训,提供用户沉浸式学习体验.交互式操作体验,VR设备能够提供沉浸式真实感的模拟场景,使得输电线路巡检内容视觉化,跨越了空间和时间的限制,有针对性的解决传统输电运 ...

  8. ggplot2(9) 数据操作

    9.1 plyr包简介 ddply {plyr}: Split data frame, apply function, and return results in a data frame. ddpl ...

  9. File判断功能(新手)

    //导入的一个类.import java.io.File;/* File判断功能*///创建的一个类.public class zylx3 { //公共静态的主方法. public static vo ...

  10. Python基础 | 数据文件的读写

    目录 txt txt的读入 txt的写出 csv xls\xlsx 在线网页数据 常用的工具 爬虫的步骤 pdf pdfrw PyPDF2 提取文档信息 word文档 其他统计软件生成文件 本文总结使 ...