Hibernate查询,数据库中无数据正常,有数据出现java.lang.NullPointerException 空指针异常

hibernate执行表与表之间多对一的查询时,如果数据库中没有数据时,一切正常,一旦将数据插入到数据库中,查询的时候将会抛出空指针异常。以下是我的*.hbm.xml的配置

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
	<class name="com.song.entity.Album" table="album" catalog="photosystem">
		<id name="albumId" type="java.lang.Integer" column="albumId">
			<generator class="identity" />
		</id>
		<property name="albumName" type="java.lang.String" column="albumName" />
		<property name="albumDesc" type="java.lang.String" column="albumDesc" />
		<property name="createDate" type="java.lang.String" column="createDate" />
		<property name="cover" type="java.lang.String" column="cover" />
		
		<many-to-one name="user" column="userId" class="com.song.entity.User" />
		<many-to-one name="kind" column="kindId" class="com.song.entity.Kind" />
		<set name="photos" inverse="true">
			<key column="albumId" />
			<one-to-many class="com.song.entity.Photo"/>
		</set>
	</class>
</hibernate-mapping>
后来 经过多方查证,需要在配置文件中的多对一的查询中加入 Lazy="false".
需要修改的地方为:

<many-to-one name="user" column="userId" class="com.song.entity.User" lazy="false"/>

<many-to-one name="kind" column="kindId" class="com.song.entity.Kind" lazy="false"/>

但我有个疑问啊,lazy的默认就是false,不写的话就会报错,写上就不抛空指针异常,这是问什么呢??求证。。。。。。


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值