- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个长期面临的问题,但没有得到答案。
我想使用 JPA 保留继承表,但收到错误消息。我为此使用 eclipselink 。
我的单元测试因该类而失败。
-- Table: PERSON
CREATE TABLE PERSON (
ID SERIAL NOT NULL PRIMARY KEY
DEFAULT nextval ('Person_Sequence'),
FIRST_NAME VARCHAR NOT NULL,
LAST_NAME VARCHAR NOT NULL,
DTYPE VARCHAR
);
-- Table: BUYER
CREATE TABLE BUYER (
ID INTEGER NOT NULL PRIMARY KEY
);
我有一个类(class)和餐 table 人员以及该类(class)人员的子类(class)买家
人员类别:
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
@Entity
@Inheritance(strategy=InheritanceType.JOINED)
public class Person {
@Id
private int ID;
@Column(name="FIRST_NAME")
private String firstName;
@Column(name="LAST_NAME")
private String lastName;
protected Person() {
}
public Person(int ID, String firstName, String lastName) {
this.ID = ID;
this.firstName = firstName;
this.lastName = lastName;
}
public int getId() {
return ID;
}
public void setId(int id) {
this.ID = id;
}
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
@Override
public String toString() {
return "Person [getId()=" + getId() + ", getFirstName()=" + getFirstName() + ", getLastName()=" + getLastName()
+ "]";
}
}
买家类别:
import java.util.ArrayList;
import java.util.Collection;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.OneToMany;
@Entity
public class Buyer extends Person {
protected Buyer() {
};
public Buyer(int id, String firstName, String lastName) {
super(id, firstName, lastName);
}
}
到目前为止还没有出现错误。但在这里您可以看到我的单元测试和我收到的错误消息:
import static org.junit.Assert.*;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.EntityTransaction;
import javax.persistence.Persistence;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
public class BuyerTest {
final private int id = 33;
final private String firstName = "Bart";
final private String lastName = "Simpson";
static EntityManagerFactory factory;
static EntityManager manager;
static EntityTransaction transaction;
@BeforeClass
public static void setup() {
factory = Persistence.createEntityManagerFactory("testEclipseLink");
assertNotNull(factory);
manager = factory.createEntityManager();
assertNotNull(manager);
transaction = manager.getTransaction();
}
@AfterClass
public static void teardown() {
if (manager == null)
return;
manager.close();
factory.close();
}
@Test
public void create() {
transaction.begin();
System.out.println("first " + firstName + "last " + lastName);
Buyer buyer = new Buyer(id, firstName, lastName);
assertNotNull(buyer);
manager.persist(buyer);
transaction.commit();
}
@Test
public void modify() {
Buyer buyer = manager.find(Buyer.class, id);
assertNotNull(buyer);
transaction.begin();
buyer.setFirstName("Homer");
transaction.commit();
teardown();
setup();
buyer = manager.find(Buyer.class, id);
assertEquals("Homer", buyer.getFirstName());
}
@Test
public void remove() {
Buyer buyer = manager.find(Buyer.class, id);
assertNotNull(buyer);
transaction.begin();
manager.remove(buyer);
transaction.commit();
buyer = manager.find(Buyer.class, id);
assertNull(buyer);
}
}
所以,如果我运行测试,我会收到此错误:
[EL Warning]: 2016-10-16 19:53:54.691--UnitOfWork(2036292945)--Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.6.4.v20160829-44060b6): org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: org.postgresql.util.PSQLException: FEHLER: NULL-Wert in Spalte »first_name« verletzt Not-Null-Constraint
Detail: Fehlgeschlagene Zeile enthält (33, null, null).
Error Code: 0
Call: INSERT INTO BUYER (ID) VALUES (?)
bind => [1 parameter bound]
它告诉我,我在 Firstname 上遇到了空约束错误。但是如果我在控制台上打印名字,它就被设置了。
我已经尝试过,如果我删除继承并仅使用我的 Buyer 类,它就可以正常工作!所以我无法弄清楚买家和人员类别之间的问题出在哪里。另外如果是 Src- 或 Table 定义问题
最佳答案
我看到的第一件事是买家是一个人,因此您需要在架构中添加外键来反射(reflect)这一点。
CREATE TABLE BUYER (
ID INTEGER NOT NULL PRIMARY KEY,
personId bigint unsigned NOT NULL,
constraint fk_personId foreign key (personId) references PERSON (id)
);
此外,在您的子类中,您还需要注释。
@PrimaryKeyJoinColumn(name="personId")
一个好主意是让表的所有 ID 自动递增
关于java - JPA持久化继承,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40073574/
我是 python 的新手。我试图找到我的文本的频率分布。这是代码, import nltk nltk.download() import os os.getcwd() text_file=open(
我对安卓 fragment 感到困惑。我知道内存 fragment 但无法理解什么是 android fragment 问题。虽然我发现很多定义,比如 Android fragmentation re
尝试对 WordPress 进行 dockerise 我发现了这个场景: 2个数据卷容器,一个用于数据库(bbdd),另一个用于wordpress文件(wordpress): sudo docker
这个问题已经有答案了: From the server is there a way to know that my page is being loaded in an Iframe (1 个回答)
我正在玩小型服务器,试图对运行在其上的服务进行docker化。为简化起见,假设我必须主要处理:Wordpress和另一项服务。 在Docker集线器上有许多用于Wordpress的图像,但是它们似乎都
我想要发生的是,当帐户成功创建后,提交的表单应该消失,并且应该出现一条消息(取决于注册的状态)。 如果成功,他们应该会看到一个简单的“谢谢。请检查您的电子邮件。” 如果不是,那么他们应该会看到一条适当
就是这样,我需要为客户添加一个唯一标识符。通过 strip 元数据。这就是我现在完全构建它的方式,但是我只有最后一部分告诉我用户购买了哪个包。 我试着看这里: Plans to stripe 代码在这
我有一个类将执行一些复杂的操作,涉及像这样的一些计算: public class ComplexAction { public void someAction(String parameter
这个问题已经有答案了: maven add a local classes directory to module's classpath (1 个回答) 已关闭10 年前。 我有一些不应更改的旧 E
我使用 fragment 已经有一段时间了,但我经常遇到一个让我烦恼的问题。 fragment 有时会相互吸引。现在,我设法为此隔离了一个用例,它是这样的: Add fragment A(也使用 ad
我的 html 中有一个 ol 列表,上面有行条纹。看起来行条纹是从数字后面开始的。有没有办法让行条纹从数字开始? 我已经包含了正在发生的事情的片段 h4:nth-child(even) {
如何仅使用 css 将附加图像 html 化? 如果用纯 css 做不到,那我怎么能至少用一个图像来做 最佳答案 这不是真正的问题,而是您希望我们为您编写代码。我建议您搜索“css breadcrum
以下是 Joshua 的 Effective Java 的摘录: If you do synchronize your class internally, you can use various te
在这里工作时,我们有一个框向业务合作伙伴提供 XML 提要。对我们的提要的请求是通过指定查询字符串参数和值来定制的。其中一些参数是必需的,但很多不是。 例如,我们要求所有请求都指定一个 GUID 来标
我有 3 个缓冲区,其中包含在 32 位处理器上运行的 R、G、B 位数据。 我需要按以下方式组合三个字节: R[0] = 0b r1r2r3r4r5r6r7r8 G[0] = 0b g1g2g3g4
我最近发现了关于如何使用 History.js、jQuery 和 ScrollTo 通过 HTML5 History API 对网站进行 Ajax 化的要点:https://github.com/br
我们有一个 Spring Boot 应用程序,由于集成需要,它变得越来越复杂——比如在你这样做之后发送一封电子邮件,或者在你之后广播一条 jms 消息等等。在寻找一些更高级别的抽象时,我遇到了 apa
我正在尝试首次实施Google Pay。我面临如何指定gateway和gatewayMarchantId的挑战。 我所拥有的是google console帐户,不知道在哪里可以找到此信息。 priva
昨天下午 3 点左右,我为两个想要从一个 Azure 帐户转移到另一个帐户的网站设置了 awverify 记录。到当天结束时,Azure 仍然不允许我添加域,所以我赌了一把,将域和 www 子域重新指
我正在使用terms facet在elasticsearch服务器中获取顶级terms。现在,我的标签"indian-government"不被视为一个标签。将其视为"indian" "governm
我是一名优秀的程序员,十分优秀!