spring-boot - Spring Boot 在应用程序启动时抛出空指针异常
问题描述
我是 Spring Boot 和 Hibernate 的新手,我遇到了一些错误,我请求帮助解决。我使用 Getters & Setters 创建了 3 个实体,如下所示:
@Entity
@Table(name="Cinema_Hall")
public class CinemaHall {
@Id
@Column(name="Hall_Name")
private String hallName;
@Column(name = "Address_Line_1")
private String addressLine1;
@Column(name = "Address_Line_2")
private String addressLine2;
@Column(name = "Address_Line_3")
private String addressLine3;
@Column(name="No_Of_Screens")
private int noOfScreens;
@OneToMany(mappedBy="cinemaHall")
private List<CinemaDetail> runningCinema = new ArrayList<> ();
}
@Entity
@Table(name = "CINEMA_DETAILS")
public class CinemaDetail {
@Id
@GeneratedValue
@Column(name="Cinema_ID")
private int cinemaID;
@Column(name="Cinema_Name")
private String cinemaName;
@Column(name="Cinema_Begin_Time")
private String beginTime;
@Column(name="Cinema_End_Time")
private String endTime;
@Column(name="Cinema_Ticket_Price")
private float ticketPrice;
@Column(name="Cinema_Screen_No")
private int screenNo;
@OneToOne
@JoinColumn(name="Seat_ID", referencedColumnName = "Cinema_ID")
@Autowired
private SeatDetail seatDetails;
@ManyToOne
@JoinColumn(name="Hall_ID", referencedColumnName="Cinema_ID")
private CinemaHall cinemaHall;
}
@Entity
@Table(name = "Screen_Seats")
public class SeatDetail {
@OneToOne(mappedBy="seatDetails")
@Id
@GeneratedValue
private int ID;
@Column(name = "Seat_No")
@Convert(converter = SeatDetailConverter.class)
private List<String> seatNo;
@Column(name = "Seat_Available")
@Convert(converter = SeatAvailabilityConverter.class)
private List<Boolean> seatAvailability;
@Transient
private final String ALPHABETS = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
}
我通过扩展 CrudRepository 编写了它们各自 DAO 的接口。服务等级如下:
@Service
public class CinemaHallRepository {
private List<CinemaHall> cinemaHalls;
@Autowired
private CinemaHallDao cinemaHall;
public CinemaHallRepository() {
System.out.println("In CinemaHallRepository Constructor");
addCinemaHall("Roxy", "Roxy Address 1", "Roxy Address 2", "Roxy Address 3", 3);
addCinemaHall("Hind", "Hind Address 1", "Hind Address 2", "Hind Address 3", 4);
addCinemaHall("iNox", "INOX Address 1", "INOX Address 2", "INOX Address 3", 5);
}
}
控制器类如下:
@RestController
public class CinemaHallController {
@Autowired
private CinemaHallRepository hallRepository;
@RequestMapping(method=RequestMethod.GET, value=("/cinemahalls"))
public List<String> getCinemaHalls() {
//hallRepository.setDefaultCinemaHalls();
return hallRepository.getCinemaHalls();
}
当我尝试运行应用程序时,控制台会抛出以下错误:
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaConfiguration.class]: Invocation of init method failed; nested exception is java.lang.NullPointerException: Cannot invoke "org.hibernate.mapping.KeyValue.getColumnIterator()" because the return value of "org.hibernate.mapping.PersistentClass.getKey()" is null
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1786) ~[spring-beans-5.3.4.jar:5.3.4]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:602) ~[spring-beans-5.3.4.jar:5.3.4]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:524) ~[spring-beans-5.3.4.jar:5.3.4]
at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) ~[spring-beans-5.3.4.jar:5.3.4]
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) ~[spring-beans-5.3.4.jar:5.3.4]
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) ~[spring-beans-5.3.4.jar:5.3.4]
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) ~[spring-beans-5.3.4.jar:5.3.4]
at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1153) ~[spring-context-5.3.4.jar:5.3.4]
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:907) ~[spring-context-5.3.4.jar:5.3.4]
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:582) ~[spring-context-5.3.4.jar:5.3.4]
at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:144) ~[spring-boot-2.4.3.jar:2.4.3]
at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:767) ~[spring-boot-2.4.3.jar:2.4.3]
at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:759) ~[spring-boot-2.4.3.jar:2.4.3]
at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:426) ~[spring-boot-2.4.3.jar:2.4.3]
at org.springframework.boot.SpringApplication.run(SpringApplication.java:326) ~[spring-boot-2.4.3.jar:2.4.3]
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1311) ~[spring-boot-2.4.3.jar:2.4.3]
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1300) ~[spring-boot-2.4.3.jar:2.4.3]
at com.cinema.hall.ProjectCinemaHallApplication.main(ProjectCinemaHallApplication.java:10) ~[classes/:na]
Caused by: java.lang.NullPointerException: Cannot invoke "org.hibernate.mapping.KeyValue.getColumnIterator()" because the return value of "org.hibernate.mapping.PersistentClass.getKey()" is null
at org.hibernate.cfg.Ejb3JoinColumn.checkReferencedColumnsType(Ejb3JoinColumn.java:810) ~[hibernate-core-5.4.28.Final.jar:5.4.28.Final]
at org.hibernate.cfg.BinderHelper.createSyntheticPropertyReference(BinderHelper.java:255) ~[hibernate-core-5.4.28.Final.jar:5.4.28.Final]
at org.hibernate.cfg.ToOneFkSecondPass.doSecondPass(ToOneFkSecondPass.java:101) ~[hibernate-core-5.4.28.Final.jar:5.4.28.Final]
at org.hibernate.boot.internal.InFlightMetadataCollectorImpl.processEndOfQueue(InFlightMetadataCollectorImpl.java:1823) ~[hibernate-core-5.4.28.Final.jar:5.4.28.Final]
at org.hibernate.boot.internal.InFlightMetadataCollectorImpl.processFkSecondPassesInOrder(InFlightMetadataCollectorImpl.java:1767) ~[hibernate-core-5.4.28.Final.jar:5.4.28.Final]
at org.hibernate.boot.internal.InFlightMetadataCollectorImpl.processSecondPasses(InFlightMetadataCollectorImpl.java:1655) ~[hibernate-core-5.4.28.Final.jar:5.4.28.Final]
at org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:295) ~[hibernate-core-5.4.28.Final.jar:5.4.28.Final]
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.metadata(EntityManagerFactoryBuilderImpl.java:1224) ~[hibernate-core-5.4.28.Final.jar:5.4.28.Final]
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:1255) ~[hibernate-core-5.4.28.Final.jar:5.4.28.Final]
at org.springframework.orm.jpa.vendor.SpringHibernateJpaPersistenceProvider.createContainerEntityManagerFactory(SpringHibernateJpaPersistenceProvider.java:58) ~[spring-orm-5.3.4.jar:5.3.4]
at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.java:365) ~[spring-orm-5.3.4.jar:5.3.4]
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.buildNativeEntityManagerFactory(AbstractEntityManagerFactoryBean.java:409) ~[spring-orm-5.3.4.jar:5.3.4]
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:396) ~[spring-orm-5.3.4.jar:5.3.4]
at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.afterPropertiesSet(LocalContainerEntityManagerFactoryBean.java:341) ~[spring-orm-5.3.4.jar:5.3.4]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1845) ~[spring-beans-5.3.4.jar:5.3.4]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1782) ~[spring-beans-5.3.4.jar:5.3.4]
... 17 common frames omitted
解决方案
@OneToOne(mappedBy = "" )
用于定义共享密钥。这里的问题是外键和主键的映射。如果您在以下 Entity 类中同时拥有@Id
并@OneToOne(mappedBy = "")
为同一列定义,Hibernate 无法理解那里定义的映射。很可能,您将不得不更改mappedBy=
' 值部分的内容。
@Entity
@Table(name = "Screen_Seats")
public class SeatDetail {
@OneToOne(mappedBy="seatDetails") // you need to remove this and define the mapping in different way
@Id
@GeneratedValue
private int ID;
....
}
推荐阅读
- tailwind-css - 有没有办法根据 Tailwind 中父类的存在来显示/隐藏元素?
- c# - 是否可以使用 oledb 将大量 > 23 万条记录的 excel 数据读取并显示到数据网格中?
- sequelize.js - Sequelize include 在带有类型列的槽表的多对多上无法正常工作
- java - 根据它的标题在CSV中查找特定的单元格值及其在同一行中的对应值
- python - 动态字典和为变量赋值
- prettier - 对 Webstorm 的车把支持
- mysql - MySQL - 按 MySQL 5 到 MySQL 8 的差异分组
- java - android-在一个imageView中显示多个图像?
- excel - 通过文本公式更改 Excel 日期格式
- reactjs - 反应重新渲染道具更改与本地状态更改