首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Hbase篇--HBase中一对多和多对多的表设计

一.前述 今天分享一篇关于HBase的一对多和多对多的案例的分析。...二.具体案例 案例一.多对多    人员-角色   人员有多个角色  角色优先级   角色有多个人员   人员 删除添加角色   角色 可以添加删除人员   人员 角色 删除添加 ?...PS:说明,两张表User表和Role表, User表中定义两个列族,第一个列族是名字,第二个列族中  多个列定义为具体的角色,列的内容定义为具体的值,即优先级(这里利用了列也能存信息,所以把角色Id定义为具体的列...,值越大代表优先级越高) 案例二.一对多 组织架构 部门-子部门   查询 顶级部门 查询 每个部门的所有子部门   部门 添加、删除子部门   部门 添加、删除 ?...PS:解释 一个表 rowkey中0代表顶级部门  1代表非顶级部门  因为顶级部门不是经常查  列族的列是具体的子部门列表。值是具体的名称。

2.1K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Spring data 数据库建表(一对一,一对多,多对多)

    如今我们对DBA的依赖越来越少,多数框架都支持实体关系映射,通过面向对象编程即可定义数据库结构。数据库设计也是在这个阶段完成的,不再需要DBA协助。...@OneToOne 一对一表结构,如下面ER图所示,users表是用户表里面有登陆信息,profile 保存的时死人信息,这样的目的是我们尽量减少users表的字段,在频繁操作该表的时候性能比较好,另外一个目的是为了横向水平扩展...OneToMany 一对多 我们要实现一个一对多实体关系,ER 图如下 +----------+ +------------+ | Classes |...OneToMany 注解,Student 表需要 ManyToOne 注解,这样就建立起了表与表之间的关系 package com.example.api.domain.test; import...ManyToMany 多对多 用户与角色就是一个多对多的关系,多对多是需要中间表做关联的。所以我方需要一个 user_has_role 表。

    3K50

    一对多场景下的exists子查询比join连表查询快这么多?

    两张表连表查询可以使用join、exists和in等方式,其中exists和in都属于依赖子查询。参考博客1给出了三种方式使用场景。...本文记录一次将join查询转换成exists查询后,性能得到了20倍以上的提升。 现有送货单(delivery_order)和送货商品明细(delivery_sku)两张表。...首次优化 查询语句中,对tenant_id、store_id和create_time等字段的限定只对sku表进行了限制,而没有对送货单表做限制,导致只有sku表使用了索引,而送货单表没能走索引。...再分析我们的业务场景:在我们的业务场景中,一个送货单对应多个商品,属于典型的一对多,使用exists就可以避免使用group by或distinct,其性能肯定能好于join。.../p/4469673.html 表连接的三种方式详解 hash join、merge join、 nested loop 4、https://blog.csdn.net/qq_40965479/article

    1.3K30

    数据库在一对一、一对多、多对多怎么设计表关系

    1、一对一可以两个实体设计在一个数据库中l例如设计一个夫妻表,里面放丈夫和妻子 2、一对多可以建两张表,将一这一方的主键作为多那一方的外键,例如一个学生表可以加一个字段指向班级(班级与学生一对多的关系...) 3、多对多可以多加一张中间表,将另外两个表的主键放到这个表中(如教师和学生就是多对多的关系) ---- 关于外键的设置: 首先,外键引用的那个列在主表中必须是主键列或者唯一列。...,并且一个学生只能属于一个班级,这就是一对多的关系; 那么设计数据库的时候就应该在学生表内存放班级的ID作为外键,为什么不在班级表内放学生呢?...) references class(classid) --本表classid是基于class表classid的外键 ) --------- 如上定义了主外键后,两个表间的关系就是一对多的关系了,...并且学生表内的classid必须依托班级表的classid存在,也就是说外键必须要主键存在的时候才能创建,例如: --在班级表为空的情况往学生表插入一条记录是不允许的: insert into students

    5K20

    Java——简单Java类深入(数据表与简单Java类、一对多映射、双向一对多映射、多对多映射)

    3、双向一对多映射 【举例】:用户-课程-考试成绩 ?...与上一个程序相比,唯一麻烦的是中间关系表上有其他字段,代码链是本次程序的重点所在。 4、多对多数据映射 【举例】:权限-权限组-用户-角色-角色权限组 ?...; 一个权限组包含多个权限,一对多关系; 一个角色对应有多个权限组,每个权限组可能有多个角色,多对多关系; //用户 class User{ private String userid;...Role r1 = new Role(10,"超级管理员角色"); Role r2 = new Role(10,"普通管理员角色"); //5、设置权限组与权限的关系,一对多...Role r1 = new Role(10,"超级管理员角色"); Role r2 = new Role(10,"普通管理员角色"); //5、设置权限组与权限的关系,一对多

    2.6K20

    MyBatis 详解(一对一,一对多,多对多)

    -- 向 person 表插入一条数据 --> insert id="addPerson" parameterType="com.ys.bean.Person"> insert into person...,多对一  基于xml配置   这里我们以班级和学生为例,一个班级里面对应多个学生,这是一对多;反过来,多个学生对应一个班级,这是多对一   ①、建立学生和班级的实体类   Student.java package...③、多对一:定义操作 Classes 表的sql映射文件classesMapper.xml <?... 基于xml配置   这里我们以 users 表和 groups 表为例,一个 users 可能加入多个 groups,而一个 groups 可能包含多个 users,故构成 多对多 的关联 ①、在数据库中建立相应的表...   ⑤、向 mybatis-configuration.xml 配置文件中注册 userMapper.xml文件   ⑥、编写测试类 //多对多

    5.2K70

    Hibernate之关联关系映射(一对多和多对一映射,多对多映射)

    ~~~ 1:Hibernate的关联映射,存在一对多和多对一映射,多对多映射:   1.1:一对多和多对一映射,举例说明:      学生和老师:        一个老师可以教多个学生 【一对多映射】...      多个学生可以被一个老师教【多对一映射】     部门与员工:       一个部门有多个员工【一对多映射】       多个员工属于一个部门【多对一映射】 1.2:多对多,举例说明:     ...项目和开发员工:【双向一对多即多对多映射】       一个项目有多个开发人员【一对多】          一个开发人员参与多个项目【一对多】 2:一对多和多对一映射,理清以下思路就可以进行简单的开发了...-- 17 多对多映射: 18 1:映射的集合属性:deve 19 2:集合属性,对应的中间表:relation...-- 16 多对多映射:员工方 17 1:映射的集合属性:project 18 2:集合属性,对应的中间表:relation

    4.7K90

    【MySQL】多对多练习案例

    多表(二) 多对多 分析 一个订单中可以有多种商品 一种商品可以被添加到多个订单上。...如: 订单1中只买了一双皮鞋 订单2中买了一双皮鞋一条裤子 此时我们需要设计第三张表来描述 订单和商品的对应关系 商品和订单多对多关系,将拆分成两个一对多。...product商品表,为其中一个一对多的主表,需要提供主键pid order订单表,为另一个一对多的主表,需要提供主键oid orderitem中间表,为另外添加的第三张表,需要提供两个外键oid和pid...INSERT INTO orderitem(pid,oid) VALUES(20, 30); #6删除商品表的数据 -- 执行异常  因为这个id在第三张表中被使用了,因为约束的限制不能直接删除 DELETE...FROM product WHERE pid = 1; 常见多对多表设计 用户和角色 角色和权限

    1.5K30

    【Mybatis】常见面试题:处理表与表之间的关系:多对一,一对多

    表的员工与部门有对应关系,实体类之间也有对应的关系 多对一 在员工实体类中加入实体类部门属性 Dept dept; 查询员工信息以及员工所对应的部门信息 方式一:级联方式处理映射关系 <resultMap...on t_emp.did=t_dept.did where t_emp.eid=#{eid} 方式二:使用association处理映射关系 association专门处理多对一的映射关系...* property:表示需要处理的多对一关系的属性名 * javaType:表示该属性的类型 <resultMap id="empAndDeptResultMapTwo" type="Emp...在部门实体类中加入员工类构成的集合 private List emps; 方式一:collection collection:用来处理一对多的映射关系 property:处理一对多关系的属性...-- collection:用来处理一对多的映射关系 property:处理一对多关系的属性 ofType:表示该属性对应的集合中存储的数据的类型

    15810
    领券