hibernate命名查询xml映射

时间:2013-02-18 18:14:02

标签: hibernate hibernate-mapping hibernate-session

如果我在我的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();

1 个答案:

答案 0 :(得分:0)

查询无效的HQL查询。它似乎包含特定于所选数据库的SQL方言的函数(date_part,age)。一种选择是使用named SQL query代替。其他选择是扩展方言以包含这些功能。