- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下条件查询:
@Transactional(
propagation = Propagation.REQUIRED,
isolation = Isolation.READ_COMMITTED,
readOnly = true
)
public List<GameSession> getGameSessions(Integer maxId,
boolean active, Integer gameId, GameType gameType,
Integer playerCategoryId, String playerEmail, String playerLogin, Date from, Date to, Integer playerId, CasinoCurrency currency,
CasinoGameSessionSortField sortField, SortOrder sortOrder,
int offset, int limit) {
Criteria criteria = getSession().createCriteria(GameSession.class);
if (maxId != null) {
criteria.add(Restrictions.le("id", maxId));
}
if (active) {
criteria.add(Restrictions.eq("active", active));
}
Criteria gameCriteria = criteria.createCriteria("game", "g");
if (gameId != null && gameId > 0) {
gameCriteria.add(Restrictions.eq("g.id", gameId));
}
if (gameType != null) {
gameCriteria.add(Restrictions.eq("g.type", gameType));
}
if (from != null) {
criteria.add(Restrictions.ge("startDate", from));
}
if (to != null) {
criteria.add(Restrictions.le("startDate", to));
}
Criteria playerCriteria = criteria.createCriteria("player", "p");
if (playerId != null) {
playerCriteria.add(Restrictions.eq("p.id", playerId));
}
if (playerCategoryId != null) {
playerCriteria.add(Restrictions.eq("p.category.id", playerCategoryId));
}
if (StringUtils.isNotBlank(playerEmail)) {
playerCriteria.add(Restrictions.like("p.email", "%" + playerEmail.toLowerCase() + "%"));
}
if (StringUtils.isNotBlank(playerLogin)) {
playerCriteria.add(Restrictions.like("p.login", "%" + playerLogin.toLowerCase() + "%"));
}
if (currency != null) {
criteria.add(Restrictions.eq("currency", currency));
}
if (sortField != null && sortOrder != null) {
Order order = (sortOrder == SortOrder.ASC) ? Order.asc(sortField.getValue()) : Order.desc(sortField.getValue());
criteria.addOrder(order);
}
criteria.setFirstResult(offset);
criteria.setMaxResults(limit);
criteria.setResultTransformer(Criteria.ROOT_ENTITY);
List<GameSession> list = (List<GameSession>) criteria.list();
//Native sql, returned by Log4j and that criteria.list() returns different result set
//Why?
return list;
}
和映射:
@Entity
@Table(name = "game_session")
public class GameSession {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private int id;
@Column(name = "last_access_date", nullable = false)
private Date lastAccessedDate;
@Column(
name = "start_date",
nullable = false,
insertable = true,
updatable = false
)
private Date startDate;
@Column(name = "end_date", nullable = true)
private Date endDate;
@ManyToOne(targetEntity = Player.class, fetch = FetchType.LAZY)
@JoinColumn(name = "player_id")
private Player player;
@ManyToOne(targetEntity = Game.class, fetch = FetchType.LAZY)
@JoinColumn(name = "casino_game_id")
private Game game;
@Column(
name = "payout",
nullable = false,
insertable = true,
updatable = true
)
private BigDecimal payout;
@Type(
type = "com.strg.utils.db.hibernate.GenericEnumUserType",
parameters = {
@Parameter(
name = "enumClass",
value = "com.strg.commons.db.entity.CasinoCurrency"),
@Parameter(
name = "identifierMethod",
value = "getValue"),
@Parameter(
name = "valueOfMethod",
value = "getByValue")
}
)
@Column(name = "currency_id", nullable = true, updatable = true)
private Currency currency;
@Column(name = "balance", nullable = true)
private BigDecimal balance;
@Column(name = "active", nullable = false)
private boolean active;
@Column(
name = "rounds_count",
nullable = false,
insertable = true,
updatable = true
)
private int roundsCount;
问题是我无法理解为什么 criteria.list()
和 log4j2
记录的 sql-query 返回不同的结果集。我真的不知道会出现什么问题?你能给我建议吗?
最佳答案
结果会有所不同,因为您的 criteria.list()
结果中可能会出现重复项。您应该替换此行:
criteria.setResultTransformer(Criteria.ROOT_ENTITY);
有了这个:
criteria.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);
这样做至少应该确保您的结果不会return duplicates.
关于java - criteria.list() 和 sql-query 返回不同的结果集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26870238/
我需要创建一个 Hibernate 标准限制,或者 3 个条件。问题是最后一个条件实际上是使用 AND 运算符的条件。 我的第一个条件: Criterion startInRange = Restri
假设我的类型为 User,其中包含带有属性 Name 的类 Tenant 的对象。 我想从数据库用户中选择,其租户包含给定名称。 在 Hibernate Criteria 中,我可以使用别名简单地实现
select (case when dob = '2020-02-03' then 'adult' else 'teenage' end) as Age
我正在使用 Java 中的 hibernate 条件进行 MySql 查询。我在下面给出了我的代码的小快照。 Criteria criteria = getCurrentSession
我正在尝试使用条件查询进行删除。但看起来不错,但在运行时显示错误。我收到如下错误: Caused by: java.lang.AbstractMethodError: org.hibernate.ej
我目前正在尝试实现半边折叠以执行增量重新网格化。我正在处理流形网格。考虑以下简单网格: 目标是将 a 折叠成 b。 然而,在这种情况下,这会导致非流形网格 我想阻止。我的问题是: 我怎样才能提前做到这
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在考虑为我的应用使用 Firebase Analytics。我很好奇: 保留的标准是什么?保留是否跟踪具有我必须发送的唯一 ID 或唯一设备的用户帐户? 如果用户从多个设备登录到我的应用程序,我将
我想测试一个“withCriteria”闭包,但不知道如何去做。我看到了如何模拟 withCriteria 调用,但没有测试闭包中的代码。在运行执行“withCriteria”的测试时,我不断收到 M
如何从以下 sql 创建 Hibernate 条件查询? String hql = "select e.employeeId,m.meetingId,e.firstname from Employee
我担心我可能已经表达了我的previous question很糟糕,所以为了清楚起见,我重新开始。 想象许多表,每个表之间存在 OneToMany 关联; 农场 -> 田地 -> RegionGrou
我将如何使用条件 API 执行以下 Hibernate 查询。我有一个对象 Parent 和 List Children。我想搜索所有 parent 并找到哪些 parent 包含指定的 child
我正在使用 Oracle,目前无法实现我需要的查询。 假设我有下表: - ID Date Type Value - 1 01/12/2016 prod 1 - 2
有没有办法用 JPA 2 CriteriaBuilder 编写与以下查询等效的内容? select * from season s1 where end = ( select max(end)
背景 我们定期对多个项目进行测试,并产生测试结果(通过或失败)。单个测试可以应用于多个项目,单个项目可以对其进行多个不同的测试。 我们需要做的是生成当前未通过测试的所有项目/测试组合的列表,以及自上次
SQL: String hql1 = "SELECT /* PARALLEL(MVR,16) PARALLEL(MVRS,16)*/ * FROM ICM MINUS SELECT I1.* FRO
为什么这是不可能的? Criteria crit1 = sess.createCriteria(Criteria1Class.class); Criteria crit2 = crit1.creat
我通常在 hibernate 状态下使用 criteria.addOrder(Order.desc("myField")); 如何在不使用 hsql 的情况下在 Hibernate 中编写此语句? s
假设我有一个具有以下值的表 Plan。 planName(VARCHAR2) | validFrom(timestamp) | validTo(timestamp) -----------------
给定映射的 hibernate 类: @Entity public class MyTestClass { /* id and stuff */ private Integer aValue;
我是一名优秀的程序员,十分优秀!