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

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

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

3K50

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

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

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

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

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

    2.1K30

    Laravel多对多关系详解【文章 - 标签】

    前言 今天弄了一天的关于文章的功能,其中主要卡在文章与标签的多对多的关系纠结中。卡了半天,终于算是解决了,不是很完美,但可以。 新建迁移文件 多对多的关系中,需要三张表。...两张主体表、一张这两张表的关系表。...这是我是文章表【articles】、标签表【tags】以及关系表【article_tag】 其中关系的命名是[article_tag]而不是tag_article 因为laravel默认是以字母升序排列...另外就是,新建迁移文件的顺序也有要求,关系表肯定是最后的,然后文章表和标签表好像随意,但我是先建文章表。...references():参照字段 on():参照表 onDelete():删除时的执行动作 这里是跟着删除,比如删除了某篇文章,我们将article_tag中包含article_id一样的记录也删除

    1.8K00

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

    1、数据表与简单Java类的映射 简单Java类是整个项目开发的灵魂,其有严格的开发标准,最为重要的是它要与数据表完全对应。...2、一对多数据映射 【举例】:课程分类 ?...3、双向一对多映射 【举例】:用户-课程-考试成绩 ?...与上一个程序相比,唯一麻烦的是中间关系表上有其他字段,代码链是本次程序的重点所在。 4、多对多数据映射 【举例】:权限-权限组-用户-角色-角色权限组 ?...; 一个权限组包含多个权限,一对多关系; 一个角色对应有多个权限组,每个权限组可能有多个角色,多对多关系; //用户 class User{ private String userid;

    2.6K20

    NHibernate 多对多映射的数据更新

    NHibernate 多对多映射的数据更新 最近在用 NHibernate 做多对多更新时突然发现 NHibernate 更新的策略很差, 对多对多关系的更新居然是先全部删除再插入全部数据, 感觉非常奇怪...session.Update(user); session.Flush(); } 上面的代码是将用户的第一个角色删除, 再添加一个新的角色, NHibernate 生成的 SQL 语句如下(仅包含对关系表...发现 StackOverflow 上也有人问类似的问题, 并且最终在 NHibernate Tip: Use set for many-to-many associations 发现了解决方案, 将多对多的映射的...不只是多对多, 如果你的集合需要更新, NHibernate 推荐的是: 19.5.2....sess.Flush(); 由此可见, bag 在多对多映射更新时性能较差, 如果不需要更新,则可以放心使用, 在需要更新时则 set 是更好的选择。

    95210

    数据库表关系之-多对多关系

    本章内容针对tortoise-orm进行多对多关系的数据分析 图片 ---- 图片 简单的多对多关系介绍 如上ER图中看到了我们的三张表:分别是access、role、user(user这张表我没放上去...多对多关系: role角色表的一条记录能够对应另外一张user用户表中的多条记录,同时user表中的一条记录也能对应role表中的多条记录,被称之为我们的多对多关系。...table = "access" 根据ER图进行关系分析 tortoise-orm维护多对多的表关系才用的是中间表的形式,通过related_name来生成表中间表前缀....角色对用户 一个角色可以对应多个用户 系统管理员角色可以对应多个用户: 张三是管理员、李四是管理员、王五也是管理员。多个用户对应的同时都是系统管理员的角色。...兄弟们: 以后在更新,torroise-orm这个多对多关系的查询我真是搞得不太明白…

    3.1K10

    【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

    还得再来聊聊Laravel中的对多对模型的一些事

    前言 之前,在文章:https://www.misiyu.cn/article/58.html 已经发过关于Laravel中的多对多关系了。 但回过头来,过了个把月再去看,我自己都忘了怎么写了。...确实看laravel的中文文档,看得糊里糊涂的。还是得在实践中理解啊。 情景假设 我有一张来源表(referers)来记录href和网页标题title。...还有一张信息表(netDisks)来记录一些东西。 目前需求是信息表里面的多个信息可能同属于来源表中的一条记录。 同样,来源表中的多条信息可能属于信心表中的一条记录。...简言之就是,这是多对多的关系。 细节 新建迁移文件就不说了。 我想说的重点是: 1、来源表和信息表可以没有任何外键约束,意思就是说各建各的,不用考虑外键什么的。...重点是第三张表,第三张表最少需要2个字段:即两张表的外键 ? 注意: 1、你想要有其他字段也行,我们这里讨论最简单的情况。 2、第三张表的命名有要求,主要是Laravel默认情况的关系。

    1.6K00

    多对多关系表的创建方式、forms组件

    多对多关系表的三种创建方式 1.全自动,Django自动创建 class Book(models.Model): title = models.CharField(max_length=20)...全部由orm创建,内置了四个操作第三张表的方法add、remove、set、clear #不足:可扩展性差,自动创建的第三张表我发扩展和修改字段 2.纯手撸 class Book(models.Model...#不足:不再支持orm跨表查询,不支持正反向查询的概念,不支持内置的第三张表操作的四个方法 3.半自动(推荐使用) 参数: through:指定第三张表关系 through_fields:指定第三张表中哪两个字段维护表与表之间的多对多关系...form_obj.cleaned_data {'username': 'jason'} # 5.forms组件中 定义的字段默认都是必须传值的,不能少传,多传取前面的 form_obj = views.MyForm...通过校验器对数据的合法性进行校验之后如果还需要对数据进行进一步校验,比如输入的字符中不能有某些数据等等,可以使用钩子函数进行数据校验。

    5.2K00

    mybatis多对一和一对多查询数据处理解读

    概述  MyBatis 的一对多、多对一,主要就是 resultMapresultMapresultMap 两个属性的使用,而一对多和多对一都是相互的,只是站的角度不同: 【一对多】association...许多结果将包成这种类型 【多对一】collection:复杂类型的集合 准备工作 由于本文是作为解读处理,在这里将不再赘述工程的搭建,只在这里只带大家过一下我们准备的实体类和pojo对象 准备的表有俩张...,一个是学生表(t_student),一个是班级表(t_clazz),学生表可以通过cid字段到班级表中查询到对应的班级,java程序控制的外键,俩张表的数据如下:  工程目录如下:  多对一 问题的引出...`cid` WHERE sid=1  查询的结果如下:  如果我们要将这条记录返回给mybatis进行的数据的封装,就需要提供一个实体类student,那么这个的时候我们需要对这个实体类的属性进行考虑...延迟加载也称为懒加载、惰性加载,使用延迟加载可以提高程序的运行效率,针对数据持久层的操作,在某些特定查询的情况下去访问特定的数据库,在其他情况下可以不访问某些数据表,尽量减少 SQL 的执行,从而达到提高速度的目的

    66440

    Power Query轻松搞定:数据透视时的多文本合并问题

    小勤:大海,能不能在数据透视的值里面实现多个文本的合并啊?比如下面这个,将评价合并在一起: 大海:当然可以啊,而且无论用Power Query还是Power Pivot,都可以轻松实现。...大海:好的,比如现在数据已经获取到了Power Query里: Step-1:透视列 小勤:聚合里用“计数”? 大海:别急嘛,咱们先用计数生成基础代码。 小勤:啊,又像做数据分组那样改函数?...大海:对啊,你看,生成的代码: 小勤:嗯。我知道了,List.Count就是表示计数,那改成Text.Combine就是合并文本了! 大海:聪明,你试试?...小勤:也对,但是,怎么加分隔符啊?这里只给了个写函数名称的地方! 大海:这种情况下,要构造自定义函数来实现。 小勤:这么复杂?...大海:没关系,自己动手多写多体会一下就好了,如果一时不太熟悉,可以先在前面写自定义函数,然后这里再调用,但是当你熟悉了,你就知道先写再调用的方式有点儿多余了。 小勤:嗯,我先试试。

    2.3K31

    数据透视的多文本合并问题——Power Pivot的动态计算

    小勤:上次在Power Query里实现了数据透视的文本合并问题,在Power Pivot里怎么实现啊?...大海:在Power Pivot里可以直接写关于多文本合并的度量,然后在做数据透视的时候就可以直接当做值来用了。比如上次那个数据,添加到数据模型后。...Step-1:创建度量值 即通过ConcatenateX函数实现文本的连接计算,这样,就可以直接在数据透视里当做“值”来使用了。...Step-2:创建数据透视表 小勤:这个看起来也很简单的样子哦。 大海:嗯,Power Query和Power Pivot功能十分强大,但使用起来都不复杂,只要多练一下就好了。...大海:也不一定,如果你有些特殊格式的报表是无法通过数据透视来实现的,那你可能只能通过Power Query来进行数据的拼接(整理)形成,但如果是能用数据透视来实现的,则可以首先考虑Power Pivot

    1.7K20
    领券