怎么用java跟数据库建立关系,java – 关系和构建数据库

请尝试以下方法:

我认为它涵盖了你所有的设计要点.

我试图在您的评论之间进行阅读,我认为您希望实现一个系统,您可以在其中捕获一些“规则”以供审核(我猜测,但示例可能是评论可以达到n在评论获得一定程度的质量之前,必须至少有m个顾客评论.如果确实如此,我创建了一个ReviewTemplate类:

> ReviewTemplate将为您需要的每个值提供属性/列.这些属性/列在Review上重复

>使用多个行填充ReviewTemplate,然后在Course中创建一行并将其链接到一个ReviewTemplate

>当课程需要审核时,将ReviewTemplate中的字段复制到Review中

>在Java中,使用复制的值实现Review的业务规则 – 而不是ReviewTemplate上的值.

为什么要复制这些值?好吧,我敢打赌,在某些时候,用户想要编辑ReviewTemplate表.如果是这样,使用编辑过的ReviewTemplates对Review对象会发生什么? ReviewTemplate上的修改值是否会以某种方式使过去的评论失效并破坏您的业务逻辑?不,因为您将规则值复制到Review,因此过去的评论不会更改.

编辑:具体问题的答案

How do you see the duplicating? I can create an entity ReviewTemplate with the specified attributes. In this entity there will be a relationship with reviewlines and feedbackscores.

我将每个ReviewTemplate视为包含特定“类型”Review的原型值,其中可能包含默认reviewLine(但可能没有意义)和默认feedbackScore.创建Review时,您将执行以下操作:

>实例化Review并使用ReviewTemplate中的值填充

>根据需要实例化尽可能多的CustomerReview对象,将它们链接到相关的Customer对象(我从之前的评论中推断出这一步.在客户自愿选择审阅课程之前,省略此步骤也是有意义的)

>(如果适用)使用ReviewTemplate的默认值填充CustomerReview属性feedbackScore

>根据需要实例化CustomerReviewLine记录

如果您遵循此方法,则无需在ReviewTemplate和CustomerReviewLines之间添加关系.

When I e.g. state that customers 1 to 4 need to fill in the review 4 specific “objects” need to be created that will hold the information and also 4 sets of the needed reviewlines and feedbackscores need to be created so they all can hold the information.

绝对.

I just don’t know how to implement this is a JPA structure so the information is hold in the db … ?

JPA允许您以多种方式解决问题,但最佳做法是手动创建数据库模式和Java类(例如,参见https://stackoverflow.com/a/2585763/1395668).因此,对于图中的每个实体,您需要:

>编写SQL DDL语句以创建表,列,主键和外键,以及

>编写用@entity注释表示的Java类.在类中,您还需要使用@id注释id(主键)以及与@OneToMany或@ManyToOne的关系(注释中的其他参数也要设置).

现在,在JPA方面,您可以执行以下操作:

ReviewTemplate template = course.getReviewTemplate(); //assuming the variable course

Review review = new Review();

review.setCourse(course);

review.setRuleOne(template.getRuleOne());

// Copy other properties here

EntityManager em = // get the entity manager here

em.persist(review);

// Assume a set or list of customers

for (Customer customer : customers) {

CustomerReview cr = new CustomerReview();

cr.setReview(review);

cr.setCustomer(customer);

cr.setFeedbackScore(template.getDefaultFeedbackScore());

// set other CustomerReview properties here

em.persist(cr);

// You can create CustomerReviewLine here as well

如果在标准EJB会话Bean中编写,这将很好地进行交易,并且您将所有新记录提交到数据库中.

编辑2:补充问题

(我假设第二条评论完全取代第一条评论)

So when I create a reviewtemplate and I link it to a bunch of customers I write the template to the db and create a bunch of reviews based on the template but linked to the specific customer and with his own unique reviewlines and feedbackscores. Like I see it now the reviewline (more a question or discription) is the same for each review (of a template), it is only the score that changes between the customers

我终于想到了解了ReviewLine.我认为这是客户输入包含CustomerReview的文本行的地方.我现在相信ReviewLine是一个特定的问题,客户被问及客户提供的反馈评分.

根据这种理解,这是一个更新的ER /类图.

请注意,有一些重大更改 – 还有几个表:

> ReviewLineTemplate提供了一个存储在ReviewTemplate上的模板问题的位置

>当实例化/插入评论(这是特定ReviewTemplate的副本)时,ReviewLineTemplates将复制为ReviewLines.复制操作允许两个重要功能:

>在创建时,可以自定义Review及其ReviewLines,而不会影响ReviewTemplate或ReviewLineTemplate

>随着时间的推移,ReviewTemplate和ReviewLineTemplate可以更新,编辑和不断改进,而无需更改客户已经回答的问题.如果CustomerFeedbackScore直接链接到ReviewLineTemplate,那么编辑ReviewLineTemplate将改变客户已回答的问题,默默地使feedbackScore无效.

> FeedbackScore已移至ReviewLine和CustomerReview之间的联接表.

请注意,此模型是完全非规范化的,这使得它更“正确”,但更难为其构建GUI.一个常见的’优化’可能是介绍:

ReviewTemplate和Review上的10个(比方说)列称为reviewLine1到reviewLine10.

CustomerReview上的10个(比方说)列通过feedbackScore10调用feedbackScore1.

>删除ReviewTemplateLine,ReviewLine和CustomerReviewLine表

这样做不规范化,可能会引入一系列其他问题.因人而异

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/564213.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++重载下标运算符

C 规定,下标运算符[ ]必须以成员函数的形式进行重载。该重载函数在类中的声明格式如下: 返回值类型 & operator[ ] (参数);或者: const 返回值类型 & operator[ ] (参数) const;使用第一种声明方式,[ ]不仅可以访问元素…

php 表情选择,php imagettftext和特定的表情符号

我遇到了一个问题,绘制了“杂项符号和象形文字”unicode块下的表情符号.这是一个示例代码:header(Content-Type: image/png);$im imagecreatetruecolor(290, 60);$grey imagecolorallocate($im, 200, 200, 200);$black imagecolorallocate($im, 0, 0, 0);imagefi…

C++ 重载自增和自减运算符

自增和自减–都是一元运算符&#xff0c;它的前置形式和后置形式都可以被重载。请看下面的例子&#xff1a; #include <iostream> #include <iomanip> using namespace std;//秒表类 class stopwatch{ public:stopwatch(): m_min(0), m_sec(0){ } public:void set…

java写一个类吧,能不能自己写个java自带的类

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼11.interface Playable {void play();}interface Bounceable {void play();}interface Rollable extends Playable, Bounceable {Ball ball new Ball("PingPang");}class Ball implements Rollable {private String nam…

C++ 重载new和delete运算符

内存管理运算符 new、new[]、delete 和 delete[] 也可以进行重载&#xff0c;其重载形式既可以是类的成员函数&#xff0c;也可以是全局函数。一般情况下&#xff0c;内建的内存管理运算符就够用了&#xff0c;只有在需要自己管理内存时才会重载。 以成员函数的形式重载 new 运…

matlab电机标定,基于模型的电机标定及高精度电机建模

概述在新能源汽车测试领域中&#xff0c;新能源汽车的驱动电机控制电流需要进行台架标定&#xff0c;目前电机台架标定中控制电流的标定是通过手动方式进行的&#xff0c;手动标定电机控制电流&#xff0c;对匹配工程师的技术要求高、工作强度大、标定周期长、标定精度也不够理…

C++ 重载强制类型转换运算符

C 中&#xff0c;类型的名字&#xff08;包括类的名字&#xff09;本身也是一种运算符&#xff0c;即类型强制转换运算符。 类型强制转换运算符是单目运算符&#xff0c;也可以被重载&#xff0c;但只能重载为成员函数&#xff0c;不能重载为全局函数。经过适当重载后&#xf…

滑动加载怎么做 php,vue之UI框架如何实现滑动加载数据

在我们移动端还有一个很常用的组件&#xff0c;那就是滑动加载更多组件。平常我们看到的很多插件实现相当复杂就觉得这个组件很难&#xff0c;其实不是的&#xff01;&#xff01;这个组件其实可以很简单的就实现出来&#xff0c;而且体验也能非常的棒(当然我们没有实现下拉刷新…

EasyX的安装与使用详细教程

EasyX 是针对 C/C 的图形库&#xff0c;可以帮助使用C/C语言的程序员快速上手图形和游戏编程&#xff0c;可以用来做些简单的演示2d类游戏&#xff0c;没有cocos2d-x那样重量级&#xff0c;学习起来也比较简单。 安装 1 . 打开Easyx官网https://easyx.cn/下载 EasyX&#xff…

二维码图片解码

二维码图片解码 现在进入了快节奏的时代&#xff0c;已经没有什么是扫码解决不了的了&#xff0c;我们光知道二维码是远远不能满足我们的需求的&#xff0c;我们需要知道二维码所表示的地址&#xff0c;但是有什么办法可以让我们对二维码进行解析然后获得地址的呢&#xff1f;…

php 删除整个目录,php 删除整个目录功能实例

这篇文章主要为大家详细介绍了php 删除整个目录功能实例&#xff0c;具有一定的参考价值&#xff0c;可以用来参考一下。对php删除整个目录的代码感兴趣的小伙伴&#xff0c;下面一起跟随512笔记的小编两巴掌来看看吧&#xff01;/*** php删除整个目录的代码** param* author 五…

C++ 强制类型转换运算符

C 将类型名作为强制类型转换运算符。 C 引入了四种功能不同的强制类型转换运算符以进行强制类型转换&#xff1a;static_cast、reinterpret_cast、const_cast 和 dynamic_cast。 强制类型转换是有一定风险的&#xff0c;有的转换并不一定安全&#xff0c;如把整型数值转换成指…

r语言如何读取matlab数据类型,[转载]R语言数据类型解析[转]

寻求帮助&#xff0c;使用 help(solve)&#xff0c;?solve 和 help(“solve”)是一样的&#xff0c;如果需要搜索可以用help.search(solve) 或者 ??solve。另外使用 help.start() 可以打开网页版的帮助&#xff0c;这个功能倒是和Matlab 的 doc 有几分相似。使用 source() 和…

java中函数过载,Java继承中成员方法的overload(重载/过载)

如果Java基础类有一个方法名被“过载”使用多次&#xff0c;在衍生类里对那个方法名的重新定义就不会隐藏任何基础类的版本。所以无论方法在这一级还是在一个基础类中定义&#xff0c;过载都会生效。public class Hide {public static void main(String[] args) {Bart b new B…

matlab 发送 126 邮件,python实现126邮箱发送邮件

用Python发送126邮件&#xff0c;供大家参考&#xff0c;具体内容如下今天想做个自动化邮件提醒的功能&#xff0c;最近刚好在学习python&#xff0c;都说python那么强大&#xff0c;想试一下python能否搞定&#xff0c;搜一下资料&#xff0c;果真可以&#xff0c;而且又简单通…

C++ auto和decltype关键字

可以用 auto 关键字定义变量&#xff0c;编译器会自动判断变量的类型。例如&#xff1a; auto i 100; // i 是 int auto p new A(); // p 是 A* auto k 34343LL; // k 是 long long有时&#xff0c;变量的类型名特别长&#xff0c;使用 auto 就会很方便。例如&#xff1a…

理查森外推法 matlab,数值代数–理查森外推法.doc

数值代数–理查森外推法实验四一、实验名称理查森外推算法二、实验目的与要求&#xff1a;实验目的&#xff1a;掌握理查森外推算法。实验要求&#xff1a;1. 给出理查森外推算法思路&#xff0c;2. 用C语言实现算法&#xff0c;运行环境为Microsoft Visual C。三、算法思路&am…

python 自动化出报表,python实现报表自动化详解

本篇文章将介绍&#xff1a;xlwt 常用功能xlrd 常用功能xlutils 常用功能xlwt写Excel时公式的应用xlwt写入特定目录(路径设置)xlwt Python语言中&#xff0c;写入Excel文件的扩展工具。可以实现指定表单、指定单元格的写入。支持excel03版到excel2013版。使用时请确保已经安装p…

C++ 右值引用

能出现在赋值号左边的表达式称为“左值”&#xff0c;不能出现在赋值号左边的表达式称为“右值”。一般来说&#xff0c;左值是可以取地址的&#xff0c;右值则不可以。 非 const 的变量都是左值。函数调用的返回值若不是引用&#xff0c;则该函数调用就是右值。之前我们了解的…

Sublime Text 3 详细安装教程

Sublime Text 3 详细安装 下载 官网下载地址https://www.sublimetext.com/3 安装 1 . 下载完成之后安装程序自动运行&#xff0c;默认安装路径&#xff0c;不要修改&#xff08;如果修改安装路径后期需要配置环境变量&#xff09; 注意&#xff1a;最好使用默认填入的安装…