0

我在代码中的查询是

 ArrayList lst = genericDao.query("select * from fdfiles where fileid = " + fileId);

在这一行我得到了例外

Caused by: org.hibernate.MappingException: No Dialect mapping for JDBC type: -4

我如何克服上述异常。

我的休眠有属性

<property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.cache.use_query_cache">false</prop>
            <prop key="hibernate.cache.use_second_level_cache">false</prop>
            <prop key="hibernate.generate_statistics">true</prop>
        </props>
    </property>

日志文件显示

java.lang.Exception: No Dialect mapping for JDBC type: -4; nested exception is org.hibernate.MappingException: No Dialect mapping for JDBC type: -4
at com.duncansolutions.databus.dao.GenericDao.query(GenericDao.java:135)
at com.duncansolutions.databus.service.mechanismmanagement.datakey.FileListByLocationDaoService.getFile(FileListByLocationDaoService.java:151)
at com.duncansolutions.databus.html.DatakeyFileDownloadController.getFilebyId(DatakeyFileDownloadController.java:34)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:174)
4

1 回答 1

0

This No Dialect mapping for JDBC type: -4当休眠尝试转换结果列表实际列表时出现异常,hibernate无法识别列dataTypes

尝试使用HSQL来获取如下记录。

假设您fdfiles的映射到FdFiles实体

Query query = session.createQuery("SELECT fd.propert1,fd.property2 FROM FdFiles fd WHERE fd.fileId = :fileId");
                query.setParameter("fileId", fileId);
                List<FdFiles> list = query.list();
于 2013-02-08T10:20:00.463 回答