如果我在我的Car.hbm.xml中放置<query..>
,我从(Session) HibernateUtil.getSessionFactory().getCurrentSession();
返回的会话为空,如果我从我的xml映射文件中删除该查询,则会话不再为null。
为什么我会收到此错误?我真的很担心这个问题。
我得到了这个xml映射:
<hibernate-mapping package="at.opendata.entitys">
<class name="Car" table="Cars">
<id name="id" column="car_Id">
<generator class="increment"/>
</id>
<set name="carDetails" table="Cardetail" cascade="all" lazy="false" fetch="select" >
<key column="car_id" not-null="true"/>
<one-to-many class="CarDetail" />
</set>
<property name="name" not-null="true"/>
<property name="vin" not-null="true"/>
</class>
<query name="dailysales">
<![CDATA[select sum(date_part('minute', age(cd.gone, cd.back))) from Car as c left join c.carDetails as cd where cd.gone is not null and cd.back is not null]]>
</query>
</hibernate-mapping>
这就是我想调用命名查询的地方:
Transaction transaction = null;
int amount = 0;
try{
Session session = (Session) HibernateUtil.getSessionFactory().getCurrentSession();
transaction = session.beginTransaction();
amount = (Integer)session.getNamedQuery("dailysales").uniqueResult();
答案 0 :(得分:0)
查询无效的HQL查询。它似乎包含特定于所选数据库的SQL方言的函数(date_part,age)。一种选择是使用named SQL query代替。其他选择是扩展方言以包含这些功能。