- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在创建一个需要与数据库交互的程序。这是一个简单的库存管理系统,因此实体是“Item”和“Patron”。
编辑:这是一个使用 Spring boot 和 spring data JPA 的 Vaadin 应用程序
首先,我将从我的 2 个类开始,为了简洁起见,省略 getter/setter。
@Table(name="item")
@Entity
public class Item implements Serializable, Cloneable {
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private long barcode;
@NotNull
private String name, type;
@NotNull
private boolean isAvailable;
@Nullable
private boolean isLate;
@Nullable
private String notes;
@Nullable
private Patron currentPatron;
@Nullable
private Patron[] history;
@Nullable
private Date checkOutDate, dueDate;
public Item() {}
public Item(long barcode, String name, String type, boolean isAvailable) {
this.barcode = barcode;
this.name = name;
this.type = type;
this.isAvailable = isAvailable;
}
public Item(long barcode, String name, String type, String notes, boolean isAvailable) {
this.barcode = barcode;
this.name = name;
this.type = type;
this.notes = notes;
this.isAvailable = isAvailable;
}
public Item(long barcode, String name, String type, String notes, boolean isAvailable, Date checkOutDate, Date dueDate, boolean isLate, Patron currentPatron, Patron[] history) {
this.barcode = barcode;
this.name = name;
this.type = type;
this.notes = notes;
this.isAvailable = isAvailable;
this.checkOutDate = checkOutDate;
this.dueDate = dueDate;
this.isLate = isLate;
this.currentPatron = currentPatron;
this.history = history;
}
}
@Entity
@Table(name="patron")
public class Patron {
@Id
private long id;
@NotNull
private String name, email;
@Nullable
private Item[] checkedOutItems;
@Nullable
private List<Item> itemHistory;
@Nullable
private boolean owesFines;
@Nullable
private int finesOwed;
public Patron() {}
public Patron(long id, String name, String email, boolean owesFines) {
this.id = id;
this.name = name;
this.email = email;
this.owesFines = owesFines;
}
public Patron(long id, String name, String email, Item[] checkedOutItems, List<Item> itemHistory, boolean owesFines, int finesOwed) {
this.id = id;
this.name = name;
this.email = email;
this.checkedOutItems = checkedOutItems;
this.itemHistory = itemHistory;
this.owesFines = owesFines;
this.finesOwed = finesOwed;
}
实际上,Patron 对象是通过使用 MSR 扫描其校园 ID 来实例化的。然后,该数据将填充顾客类别的姓名、电子邮件和 ID 字段。
结账时,顾客首先用MSR刷卡(系统会确认他们在数据库中,如果不在数据库中,则将其添加)。扫描他们的磁条后,他们想要的元素的二维码就会被扫描,这样我们就可以将该元素绑在他们身上。
当某个项目被顾客 checkout 时,我们需要从顾客表中获取他们的id、姓名和电子邮件,然后填充其其余变量: check_out_date
, due_date
等
顾客可以 checkout 许多商品,但只能向顾客 checkout 一件商品。这是否建立了OneToMany
关系?赞助人 -> 元素(
我的思考过程如下:
对于赞助对象有一个 Items 数组来存储他们当前拥有的元素的条形码。有一个项目数组列表来存储有关哪个顾客拥有它以及何时拥有它的信息 List<Item> history
,这样代码就很简单 history.addToFront(something)
对于项目对象有一个 Patron 对象来查看谁拥有它有一个顾客数组列表,可以查看所有 checkout 时间
问题1:使用数组和列表作为两个类的实例数据是否多余?
Q1.2:对象数组和对象列表是否适合这种场景的数据结构?
Q1.3:使用javax.persistence.*;
有什么区别吗?和org.springframework.data.annotation.*;
对于 ID 之类的内容,import javax.validation.constraints.NotNull;
之间有区别吗?和import org.springframework.lang.NonNull;
Q2:这会产生 OneToMany
赞助人和元素之间的关系?
Q3:为了实现这一目标,我相信我的数据库中需要一些额外的表。我在想这样的事情:(并且我意识到在实现新模式时我需要包含适当的 spring 注释)
项目表
create table item(barcode int(10) primary key, name varchar(64) not null, type varchar(64) not null, availability boolean, is_late boolean, note varchar(255), check_out_date Datetime, due_date Datetime); #foreign keys for currentPatron and Patron History
订阅者表
create table patron(id int(10) primary key, name varchar(64) not null, email varchar(64) not null, owes_fines boolean, fines_owed int); #foreign key to item table?
Patron_Item_History 表:这将从订阅者表中提取id、name、email,然后从项目表中提取id、check_out_date、due_date?
Item_Patron_History 表:与上表结构类似?
提前谢谢您。
最佳答案
好的,就到这里,
我假设您正在使用 Spring Boot、Hibernate 作为 ORM 以及可能某种类型的关系数据库 (MySQL) 来构建应用程序。
关于数据库设计:
是的,这里的 Patreon 对象是与 Item 实体具有 OneToMany 关系的拥有实体(因为一个 Patreon 可能有 N 个对象)。您的 Patreon 实体可以进行以下重新设计:
1) 尝试使用非原始类型,尤其是表键(长 id -> 长 id)。
2) 丢失checkOutItems 数组以及itemHistory 列表。首先,关系应该使用集合而不是数组来建模。其次,你不需要这两个。您永远不会以这种方式存储checkedOutItems 或itemHistory。相反,创建一个 List<Item> items
它将在描述关系时存储 Patreon 项目(以下是一些示例: http://www.baeldung.com/hibernate-one-to-many )
3) 同样,对于 Item 实体,您需要丢失历史数组。您唯一需要的是对所属实体(本例中为 Patreon)的引用,从而完成关系的 ManyToOne 方面。
4) 请注意,日期字段应使用 @Temporal
进行注释。还提供正确的类型(您可以阅读更多内容)。
5)项目类通常应该重新设计。
5) 上述所有内容都准备就绪后,假设您使用的是 Spring,您可以创建一个存储库,您可以使用它来查询 Patreon 对象,从而检索对象及其相关实体(项目)。
关于您的问题:
Q1:是的,它看到了。请参阅上文了解更多信息。
Q1.2:没有数组不是。列表或更好的集合更适合。
Q1.3:是的。第一个是关系型中使用的JPA注解 数据库,而第二个是 Spring Data 特定注释 由非此类的数据库和框架使用 (关系)或没有定义标准持久性 API(例如 日本公共(public)事务局)。对于NonNull和NotNull与第一个大致相同 一个实际上取代了后一个(已经完成的事情 经常)。我看到的唯一区别是目标。您可以阅读 更多这里: https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/lang/NonNull.html https://docs.oracle.com/javaee/7/api/javax/validation/constraints/NotNull.html
问题2:是的。见上文。
Q3:通过一些巧妙的设计,我认为不需要更多,但是 嘿,如果你觉得这对你有帮助,为什么不呢。只是不要过度杀伤 设计及其复杂性
关于java - 在 JPA 中保留非原始数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50865099/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!