利用日期函数查询

    最近做一个项目,里面要涉及到指定某个时间字段与当前日期进行比较作为查询条件,下面是一些总结,以免以后忘记。

//要求:参加工作时间满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对用的数据类型");

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值