在models.py中大部分的class对应数据库中的表,那么我们就从AuditMixinNullable这个类开始我们的模型解析。

AuditMixin:这个类是FAB(Flask  AppBuild)中的,它的作用是向子类中加入create_by_fk、create_by、changed_by_fk、changed_by、changed_on、create_on等属性,并且这些值不能为空

AuditMixinNullable:这个类是AuditMixin子类,但是对AuditMixin类的属性进行了修改,让AuditMixin相关属性值可以为空

AuditMixinNullable的子类:AuditMixinNullable的13个子类,对应数据库中13张表,类与表的对应关系如下:

Model类

数据表

说明

Database

dbs

对应superset中对数据库连接配置。

SqlaTable

tables

dbs中数据库引入到superset中的表,与dbs表是一对多的关系。

TableColumn

table_columns

对应tables中表的数据字段,与tables表是一对多的关系。

SqlMetric

sql_metrics

对表字段进行可聚合纬度度量,与tables表是一对多的关系。

Slice

slices

切片表。

slice_user

slices与ab_user的关联表,slices与ab_user多对多关系

Dashboard

dashboards

仪表盘表。

dashboard_slices

仪表盘与切片之间的关联表,由此可以看出,slices表与dashboards表是多对多的关系。

dashboard_user

dashboards与ab_user的关联表,dashbaoards与ab_user是多对多关系。

DruidCluster

clusters

druid集群配置表

DruidDatasource

datasources

druid的数据源配置,与clusters是一对多关系

DruidColumn

columns

druid数据源的字段表,与datasource是一对多关系

DruidMettic

metrics

druid数据源的度量表,与datasource是一对多关系

DatasourceAccessRequest

access_request

访问datarource和dbs访问请求表

Url

url

用于短url功能

CssTemplate

css_templates

css的模板表

对比ORM类,查看对应数据库表,我们发现以上16张表除了dashboard_slices、dashboard_user、slice_user关联表之外,其余13张表中都有created_by_fk和changed_by_fk这2个字段,AuditMixin及其子类AuditMixinNullable的功能不言而喻。

Datasource不对应数据库中的表,它的功能是提供其子类SqlaTable、DruidDatasource类公用的的部分。

Model类

数据表

说明

Query

query

记录在SQL Lab菜单中,SQL Query子菜单中执行Run Query的查询历史

FavStar

favstar

用于记录用户喜欢的仪表盘或切片

Log

logs

记录superset对数据库的操作

KeyValue

keyvalue

用户任何类型的键值对存储

此外,在models.py中还有其它单独的类需要介绍,请看下面:

Model类

说明

QueryResult

此类用于在SQL Lab菜单中,SQL Query子菜单中执行Run Query时对查询结果的反馈。

JavascriptPostAggregator

下面介绍下fab中的用户权限的实体类:8

Model类

数据表

说明

User

ab_user

用户表。

RegisterUser

ab_register_user

注册用户表。

Role

ab_role

角色表。

ab_user_role

用户与角色的关联表,ab_user与ab_role是多对多关系。

ab_permission_view_role

权限视图与角色的关联表,ab_permission_view与ab_role是多对多关系

Permission

ab_permission

权限表

PermissionView

ab_permission_view

权限与视图菜单的关联表,ab_permission与ab_view_menu是多对多关系

ViewMenu

ab_view_menu

视图菜单表

表之间的关联图

1-3 superset数据模型的更多相关文章

  1. Superset

    Superset是一款可自助.可交互,可视化非常不错的产品 Superset is a data exploration platform designed to be visual, intuiti ...

  2. MongoDB学习笔记~数据模型属性为集合时应该为它初始化

    回到目录 今天要说一下技术点,我们在设计mongodb的数据模型时,如果属性是数组或者集合类型,我们在模型初始化时,需要为它们初始化一下,否则在数据库里将会被存储为NULL,当被存储为NULL时,我们 ...

  3. 从零自学Hadoop(20):HBase数据模型相关操作上

    阅读目录 序 介绍 命名空间 表 系列索引 本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 序 ...

  4. Entity Framework 教程——创建实体数据模型

    创建实体数据模型: 本文将带你创建实体数据模型(EDM)SchoolDB数据库和理解基础建设模块. 实体数据模型(EDM)是用于描述实体之间关系的一种模型,以下将使用Visual Studio 201 ...

  5. ZooKeeper:数据模型

    ZooKeeper数据模型 ZNode ZNode 分类 Stat Watcher Watcher工作原理 Watcher事件说明 Watcher注册 事件发布 示例 ZooKeeper 数据模型 整 ...

  6. 从零自学Hadoop(21):HBase数据模型相关操作下

    阅读目录 序 变量 数据模型操作 系列索引 本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 序 ...

  7. ExtJS 数据模型

    自定义数据模型 数据模型类其实就是一个继承自Ext.data.Model 的类. Ext.define('MyApp.User', { extend: 'Ext.data.Model', fields ...

  8. 在powerdesigner中创建物理数据模型

    物理数据模型(PDM)是以常用的DBMS(数据库管理系统)理论为基础,将CDM/LDM中所建立的现实世界模型生成相应的DBMS的SQL语言脚本.PDM叙述数据库的物理实现,是对真实数据库的描述 PDM ...

  9. Visual 2015创建新项,缺少ADO.NET 实体数据模型的解决方法

    现在的某度查资料真的很麻烦,突然我自身的VS2015创建EF的时候找不到 ADO.NET 实体数据模型,但是使用CodeFrist是可以生成数据表的.所有特别郁闷. 打开界面如下 某度半天,都没有查出 ...

随机推荐

  1. Python之路,Day8 - 面向对象编程进阶

    本节内容: 面向对象高级语法部分 经典类vs新式类 静态方法.类方法.属性方法 类的特殊方法 反射 异常处理 Socket开发基础 作业:开发一个支持多用户在线的FTP程序 面向对象高级语法部分 经典 ...

  2. UML_01_画图工具

    一.推荐工具 1.processon 在线画图,类型丰富 www.processon.com 2.StarUML staruml.io 破解方法 StarUML 3.0.2 (Crack + Keyg ...

  3. droppable放置组件

    Droppable 放置组件 所谓放置,就将一个事物入一个事物内触发各种效果,这个组件不依赖于其他组件.1.加载方式 //class 调用 <div id="dd" clas ...

  4. vue-keep-alive

    查看github源代码    https://github.com/Diamondjcx/vue-test Vue keep-alive实践总结   <keep-alive>是Vue的内置 ...

  5. PHPStorm 使用正则批量查询替换并自动转换大小写的方法

    PHPStorm 的项目查询替换功能那是非常非常强大的, 速度也很快, 配合正则更加灵活强大. 一般的正则查询替换没什么太多好说的, 这里主要说说比较少用的 大小写自动转换的问题, 也是比较少用但很有 ...

  6. 哈工大LTP语言分析:分词、词性标注、句法分析等

    1. LTP介绍和安装 LTP语言云官网  在线演示 | 语言云(语言技术平台云 LTP-Cloud) 安装LTP的python接口包 $ sudo pip install pyltp 模型文件下载 ...

  7. iOS如何限制使用SDK的版本? 解决iOS项目的版本兼容问题

      更新 2015-11-16 感谢微博好友@zyyy_000的评论,补充了为什么要在+ (void)load方法里面做Method Swizzling. 前言 最近,在做项目时,因为某种原因,突然要 ...

  8. 为什么要重写toString()方法和hashcode()方法

    一.toString(): 在Object类里面定义toString()方法的时候返回的对象的哈希code码,这个hashcode码不能简单明了的表示出对象的属性.所以要重写toString()方法. ...

  9. 我个人所有的独立博客wordpress都被挂马

    晕,所有的独立博客都中了这个,难怪访问有点慢,今天使用谷歌浏览器 来自知名恶意软件散布者 ***.net 的内容已经插入此网页.现在访问此网页很可能会导致您的计算机受到恶意软件入侵. 恶意软件是一种不 ...

  10. gulp使用 实现文件修改实时刷新

    gulp例子:https://github.com/Aquarius1993/gulpDemo 淘宝镜像:$ npm install -g cnpm --registry=https://regist ...