yangkaikai 2009-05-13 13:54
浏览 333
已采纳

hibernate的hql中如何实现类型转换

我写的hql如下:
from Test t where cast(t.id as string) like '%"+test.getId().toString()+"%'
出现异常如下,好像是hql错误,但不知道怎么改
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'string)like '%1%' )' at line 1
org.springframework.dao.InvalidDataAccessResourceUsageException: could not execute query; nested exception is org.hibernate.exception.SQLGrammarException: could not execute query
at org.springframework.orm.hibernate3.SessionFactoryUtils.convertHibernateAccessException(SessionFactoryUtils.java:612)
at org.springframework.orm.hibernate3.HibernateAccessor.convertHibernateAccessException(HibernateAccessor.java:412)
at org.springframework.orm.hibernate3.HibernateTemplate.execute(HibernateTemplate.java:377)
at org.springframework.orm.hibernate3.HibernateTemplate.find(HibernateTemplate.java:840)
at org.springframework.orm.hibernate3.HibernateTemplate.find(HibernateTemplate.java:832)
at com.jidi.dao.impl.TestDaoImpl.findTest(TestDaoImpl.java:26)

String 大小写开头都试过了

  • 写回答

1条回答 默认 最新

  • iteye_18973 2009-05-13 18:05
    关注

    我很不解的是你为什么要 cast(t.id as string) 把你的id转换为string,直接不能查吗?我刚试了下可以查

    gethibernateTemplate().find("from Test t where id like '%"+test.getId()+"%' ");
    这样查肯定没问题!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services
  • ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏
  • ¥15 模糊pid与pid仿真结果几乎一样
  • ¥15 java的GUI的运用
  • ¥15 我想付费需要AKM公司DSP开发资料及相关开发。
  • ¥15 怎么配置广告联盟瀑布流
  • ¥15 Rstudio 保存代码闪退
  • ¥20 win系统的PYQT程序生成的数据如何放入云服务器阿里云window版?
  • ¥50 invest生境质量模块