- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个带有两个 Date
字段的持久对象,如下所示
@Temporal(TemporalType.TIMESTAMP)
private Date generated;
@Temporal(TemporalType.TIMESTAMP)
private Date expirationTime;
在对象构造时,expirationTime
根据生成
字段进行初始化
this.expirationTime = new Date(generated.getTime() + ttlMillis);
现在我尝试使用 JPA 查询从数据库中删除所有过期的对象
Query q = em.createQuery("delete from MyObject t where CURRENT_TIMESTAMP > t.expirationTime");
q.executeUpdate();
但是运行一个简单的测试
MyObject o = new MyObject(somePastDate, someTTL);
em.persist(o);
... create the query above
q.executeUpate();
显示没有行被删除。关于我做错了什么有任何线索吗?我正在 HSQLDb 上运行测试并使用 Hibernate 作为我的 JPA 提供程序。
编辑:已解决,但我不确定为什么这个版本应该以不同的方式工作。
Query q = em.createQuery("delete from MyObject t where :now > t.expirationTime");
q.setParameter("now", new Date());
q.executeUpdate();
如果与其他字段比较失败,CURRENT_TIMESTAMP
有什么用?
最佳答案
您没有设置任何参数,查询必须获取命名参数:
Query q = em.createQuery("delete from MyObject t where CURRENT_TIMESTAMP > :expirationTime");
q.setParameter("expirationTime" , yourObject.getExpirationTime());//or your getter
q.executeUpdate();
我添加了一个链接来强制执行主题 here .
检查它是否有效:-)
关于java - JPA 时间戳比较不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16567022/
给定一个带有多个 date_time 戳的字符串,我想 提取第一个戳及其前面的文本 候选字符串可以有一个或多个时间戳 后续的 date_time 戳记将被 sep="-" 隔开 后续date_time
是否可以合并从相机拍摄的文本和照片?我想在照片上标记日期和时间,但我在 Google 上找不到任何内容。 最佳答案 使用下面的代码来实现你所需要的。 Bitmap src = Bitm
有没有办法通过 Graph API 戳另一个用户?基于this post ,并使用 Graph Explorer ,我发布到“/USERID/pokes”,我已经授予它(Graph API 应用程序和
我有两个向左浮动的元素。一个是 body 的第一个 child ,另一个是容器的第一个 child ,容器是 body 的第二个 child 。 ...
我是一名优秀的程序员,十分优秀!