最近做一个项目,里面要涉及到指定某个时间字段与当前日期进行比较作为查询条件,下面是一些总结,以免以后忘记。
//要求:参加工作时间满2年,8年,16年的员工可以晋级
//表名:UserInfo,其中工作时间字段:workDate,类型是时间类型
from UserInfo as userInfo where (YEAR(current date) - YEAR(date(userInfo.workDate))=2) or (YEAR(current date) - YEAR(date(userInfo.workDate))=8) or (YEAR(current date) - YEAR(date(userInfo.workDate))=16)
sql写完了,拿到hibernate中测试,发现如果底层实现的是用createQuery获得query执行是行不通的,因为 createQuery是支持存HQL语言的写法,因为这个时间函数是DB2特有的,所以底层只能调用createSQLQuery获得query来执行,并且,如果from之前要是想查询指定字段值,还要调用query.addScalar("字段名","字段在hibernate对用的数据类型");