- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在使用 hibernate 来尝试与 SQL 进行映射。
每次我尝试运行代码时都会收到错误:
org.hibernate.AnnotationException: mappedBy reference an unknown
target entity property: Catalog.primaryKey.suppliers in
Suppliers.catalogSet There is an error:java.lang.NullPointerException
我已经进行了三次检查,以确保我正确映射了所有内容,但我必须遗漏一些东西。有谁知道为什么我给定的代码会得到一个空指针?这些是我的类(class)代码:
导入javax.persistence.*;
@Entity
@Table(name = "catalog")
@AssociationOverrides({
@AssociationOverride(name = "primaryKey.suppliers",
joinColumns = @JoinColumn(name = "sid")),
@AssociationOverride(name = "primaryKey.parts",
joinColumns = @JoinColumn(name = "pid"))
})
public class Catalog {
//Composite ID
private CatalogId primaryKey = new CatalogId();
//Additional Column
private String cost;
@EmbeddedId
public CatalogId getPrimaryKey() {
return primaryKey;
}
public void setPrimaryKey(CatalogId primaryKey) {
this.primaryKey = primaryKey;
}
@Transient
public Suppliers getSuppliers(){
return getPrimaryKey().getSupplier();
}
public void setSuppliers(Suppliers supplier){
getPrimaryKey().setSupplier(supplier);
}
@Transient
public Parts getParts(){
return getPrimaryKey().getParts();
}
public void setParts(Parts part){
getPrimaryKey().setParts(part);
}
@Column(name = "cost")
public String getCost() {
return cost;
}
public void setCost(String cost) {
this.cost = cost;
}
}
import java.io.Serializable;
import javax.persistence.*;
@Embeddable
public class CatalogId implements Serializable{
private Suppliers suppliers;
private Parts parts;
@ManyToOne (cascade = CascadeType.ALL)
public Suppliers getSupplier() {
return suppliers;
}
public void setSupplier(Suppliers suppliers) {
this.suppliers = suppliers;
}
@ManyToOne(cascade = CascadeType.ALL)
public Parts getParts() {
return parts;
}
public void setParts(Parts parts) {
this.parts = parts;
}
}
import java.util.*;
import javax.persistence.*;
@Entity
@Table(name = "suppliers")
public class Suppliers {
private long sid;
private String sname;
private String address;
private Set<Catalog> catalogSet = new HashSet<Catalog>();
public Suppliers(String sname, String address) {
this.sname = sname;
this.address = address;
}
public Suppliers() {
}
@Id
@GeneratedValue
@Column(name = "sid")
public long getSid() {
return this.sid;
}
public void setSid(long sid) {
this.sid = sid;
}
@Column(name= "sname")
public String getSname() {
return this.sname;
}
public void setSname(String sname) {
this.sname = sname;
}
@Column(name = "address")
public String getAddress() {
return this.address;
}
public void setAddress(String address) {
this.address = address;
}
@OneToMany(mappedBy = "primaryKey.suppliers", cascade = CascadeType.ALL)
public Set<Catalog> getCatalogSet() {
return catalogSet;
}
public void setCatalogSet(Set<Catalog> catalogSet) {
this.catalogSet = catalogSet;
}
public void addRecipe(Catalog catalog){
this.catalogSet.add(catalog);
}
}
import java.util.*;
import javax.persistence.*;
@Entity
@Table(name = "parts")
public class Parts {
private long pid;
private String pname;
private String color;
private Set<Catalog> catalogSet = new HashSet<Catalog>();
public Parts(String pname, String color) {
super();
this.pname = pname;
this.color = color;
}
public Parts() {
super();
}
@Id
@GeneratedValue
@Column(name = "pid")
public long getPid() {
return pid;
}
public void setPid(long pid) {
this.pid = pid;
}
@Column(name = "pname")
public String getPname() {
return pname;
}
public void setPname(String pname) {
this.pname = pname;
}
@Column(name = "color")
public String getColor() {
return color;
}
public void setColor(String color) {
this.color = color;
}
@OneToMany(mappedBy = "primaryKey.parts", cascade = CascadeType.ALL)
public Set<Catalog> getCatalogSet() {
return this.catalogSet;
}
public void setCatalogSet(Set<Catalog> catalogSet) {
this.catalogSet = catalogSet;
}
public void addCatalog(Catalog catalog){
this.catalogSet.add(catalog);
}
}
这是我的(未完成的查询代码):
import org.hibernate.*;
import org.hibernate.boot.*;
import java.util.Iterator;
import java.util.List;
import java.util.Set;
import javax.swing.*;
public class HibernateHql
{
public static void main(String[] args)
{
HibernateSession hibernateSession = new HibernateSession();
SessionFactory sessionFactory;
Session session;
String option = "";
String instruction = "Enter a: Return distinct sids and snames of suppliers who supply a red part or a green part." + "\n" +
"Enter b: Return distinct pids, pnames, and the maximum cost of that part amoung all suppliers that offer the part and that maximum cost is less than 70." + "\n" +
"Enter c: Insert a new catalog row given the supplier id, the part id, and the cost fromthe user of your program." + "\n" +
"Enter d: Quit Program";
try
{
while(true)
{
option = JOptionPane.showInputDialog(instruction);
hibernateSession.setUp();
sessionFactory = hibernateSession.getSessionFactory();
session = sessionFactory.openSession();
session.beginTransaction();
if(option.equals("a"))
{
List results = session.createQuery("select distinct c from Parts p join p.catalogSet c where p.color = :color1 or p.color = :color2").setParameter("color1", "red").setParameter("color2", "green").getResultList();
String toShow = "These are suppliers who supply a red or green part:\n";
for(int i=0;i<results.size();i++)
{
Suppliers theSupplier = (Suppliers)((Catalog)results.get(i)).getSuppliers();
toShow += (i+1) + ") " + theSupplier.getSname() + "\n";
}
JOptionPane.showMessageDialog(null, toShow);
}
else if(option.equals("b"))
{
List results = session.createQuery("select max(r.cost)from Suppliers s inner join s.catalogSet r group by f").getResultList();
String toShow = "These are all parts:\n";
for(int i=0;i<results.size();i++)
{
Parts thePart = (Parts)((Catalog)results.get(i)).getParts();
String cost = ((Catalog)results.get(i)).getCost();
if(Integer.parseInt(cost) <= 70){
toShow += (i+1) + ") " + thePart.getPname() + " " + cost;
}
}
JOptionPane.showMessageDialog(null, toShow);
}
else if(option.equals("c"))
{
String allSuppliers = "SID" + "....." + "SNAME" + "\n";
List allS = session.createQuery("from Suppliers").getResultList();
for(int i=0;i<allS.size();i++)
{
Suppliers theSupplier = (Suppliers)allS.get(i);
allSuppliers += theSupplier.getSid() + "....." + theSupplier.getSname() + "\n";
}
JOptionPane.showMessageDialog(null, allSuppliers);
String supplierID = JOptionPane.showInputDialog("Enter Supplier ID: ");
String allParts = "PID" + "....." + "PNAME" + "\n";
List allP = session.createQuery("from Parts p where p.color = :color").setParameter("color", "blue").getResultList();
for(int i=0;i<allS.size();i++)
{
Parts theParts = (Parts)allP.get(i);
allParts += theParts.getPid() + "....." + theParts.getPname() + "\n";
}
JOptionPane.showMessageDialog(null, allParts);
String partsID = JOptionPane.showInputDialog("Enter Parts ID: ");
// List results = session.createQuery("select f1 from Food f1 where f1 not in (select distinct r.primaryKey.food from Ingredient i inner join i.recipeSet r where i.iname = :iname)").setParameter("iname", "Green Onion").getResultList();
// String toShow = "These foods don't have green onion:\n";
// for(int i=0;i<results.size();i++)
// {
// Food theFood = (Food)results.get(i);
// toShow += (i+1) + ") " + theFood.getFname() + "\n";
// }
// JOptionPane.showMessageDialog(null, toShow);
}
else
{
break;
}
session.getTransaction().commit();
session.close();
}
JOptionPane.showMessageDialog(null, "Good Bye");
}
catch(Exception e)
{
System.out.println("There is an error:");
System.out.println(e.toString());
}
}
}
预先感谢您的帮助!
最佳答案
在 Suppliers
类中,您已映射 catalogSet
如下:
@OneToMany(mappedBy = "primaryKey.suppliers", cascade = CascadeType.ALL)
public Set<Catalog> getCatalogSet() {
return catalogSet;
}
我在 Suppliers
类中没有找到任何名为 primaryKey
的字段。我认为你应该在这里使用 sid
来映射 catalogSet
和 Suppliers
类之间的关系。
如果我误解了您的问题,请告诉我。
关于java - org.hibernate.AnnotationException : mappedBy reference an unknown target entity property. 有错误 : java. lang.NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52936529/
我想在 java 中声明一个对象,就像在 C++ 中指向指针的指针,让我给你看一个例子: //*** At the application startup //Initialize a setting
考虑这段代码, struct A {}; struct B { B(const A&) {} }; void f(B) { cout << "f()"<
我正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试过的
我目前正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试
这个问题在这里已经有了答案: Add managed DLL dependencied to unmanaged C++ project (1 个回答) 关闭 6 年前。 我有这样一个场景: 使用
这是一个常见问答的集合,这也是一个社区维基,所以每个人都被邀请参与维护它。。正则表达式正在遭受给我ZE代码类型的问题和没有解释的糟糕答案。此参考旨在提供指向质量问答的链接。。此参考适用于以下语言:PH
我正在尝试在方案中模拟堆栈。我正在使用 DrScheme 并选择语言 R5RS。我需要创建 pop、push 和 peek 的函数。但我无法弄清楚如何通过引用传递。我已经阅读了一些关于盒子的信息,但是
我陷入了这个错误。我将代码部署在生产服务器上,它在端口 80 上运行。当我尝试登录管理页面时。如图所示,它给了我 403 错误。 可能是什么原因?我的 Django 代码或 nginx 配置有问题吗?
这是一段简单的 C++ 代码: A foo(){ A a; // create a local A object return a; } void bar(const A & a_r){ }
我正在使用从 torrenteditor 获取的 php 脚本来创建 torrent 文件,但是当我使用指定的方法创建新的 torrent 文件时,torrent 文件被创建但我收到很多通知。,就像这
MySQL: REFERENCES vs FOREIGN KEY + REFERENCES 我认为 REFERENCES 是更冗长的 FOREIGN KEY REFERENCES 语法的某种速记语法。
我想使用基于另一个方法引用的方法引用。这有点难以解释,所以我给你举个例子: Person.java public class Person{ Person sibling; int a
Java/C# 语言律师喜欢说他们的语言通过值传递引用。这意味着“引用”是在调用函数时复制的对象指针。 同时,在 C++ 中(以及在 Perl 和 PHP 中更动态的形式),引用是某个其他名称(或动态
当我需要实现递归 lambda 时,通常我这样做: auto factorial = [](auto& self, int n) -> int { return n == 0 ? 1 : n
我目前正在研究 DDD ,需要一些启发。 我有两个实体 Temple TempleVariant Temple(听筒)包含基本信息(名称,描述等),并具有n个变体,它们具有技术描述(CAD绘图,尺寸,
在 Grails 中 belongsTo允许一个域类与另一个域类建立级联关系。使用belongsTo时有两种类型的关系:引用和无引用。 Reference 在拥有的对象上创建属性,而 No Refer
我正在使用 AWS 和 Django Rest Framework 开发 Web 应用程序。(Django:v1.8,DRF:v3) 我一直在为 POST 多部分表单请求获取 django.reque
我按照下面的定义公开了 WCF 端点, 当我在 .NET 3.5 中添加“服务引用”时,我们在代理中获得了以下类,这非常好: [Syst
我在玩 constexpr 引用时产生了这种感觉。但问题本身与 constexpr 无关,只是被它揭示。 我们知道有“指向const的指针”,也有“const指针”。顺便说一句,由于后者的使用比前者少
我有 2 种类型的 refences,它们中的每一种都可以正常工作。 我尝试使用每一个并在 project build 中得到相同的结果。 请向我解释 COM 引用和引用之间的区别。 谢谢你。 最佳答
我是一名优秀的程序员,十分优秀!