ebean和手动输入SQL查询之间的结果不同?

时间:2013-05-06 13:09:15

标签: playframework-2.1 ebean

我已经构建了一个MySQL查询,当我通过phpMyAdmin尝试它时返回452个条目,这是查询:

SELECT csp.id FROM child_subscription_prices csp 
JOIN child_moments cm ON csp.child_moment_id = cm.id 
JOIN moments m ON cm.moment_id = m.id 
JOIN poles p ON m.pole_id = p.id 
JOIN persons pr ON pr.id = csp.payer_id 
WHERE cm.day BETWEEN '2013-1-15' AND '2013-1-17' AND p.type_id IN (1,2,3) AND csp.center_id = 1 
ORDER BY pr.lastname ASC

但是当我使用Ebean(Play!Framework 2.1.1)调用它时,就像这样:

SimpleDateFormat format = new SimpleDateFormat("y-M-d");
StringBuilder querySql = new StringBuilder();
querySql.append("SELECT csp.id FROM child_subscription_prices csp ");
querySql.append("JOIN child_moments cm ON csp.child_moment_id = cm.id ");
querySql.append("JOIN moments m ON cm.moment_id = m.id ");
querySql.append("JOIN poles p ON m.pole_id = p.id ");
querySql.append("JOIN persons pr ON pr.id = csp.payer_id ");
querySql.append("WHERE cm.day BETWEEN :start AND :end AND p.type_id IN (:poles) AND csp.center_id = :center ");
querySql.append("ORDER BY pr.lastname ASC;");       

SqlQuery query = Ebean.createSqlQuery(querySql.toString());
query.setParameter("start", format.format(start));
query.setParameter("end", format.format(end));
query.setParameter("poles", StringUtils.join(poleIds.toArray(), ","));
query.setParameter("center", Session.getCenter().getId());

List<SqlRow> rows = query.findList();
rows.size(); // Return 409 !!

当然,我在Java中测试了参数并对它们进行了比较,它们是完全相同的! (我甚至更新了我的第一个查询以匹配日期(2013-01-15 =&gt; 2013-1-15,就像用Java制作的那个!

我没有任何线索为什么我使用Java减少50个条目,是否有一个特定的Ebean配置因为任何原因不遵循某些相关数据库,或类似的东西可以解释这些差异?

更新

我还尝试计算Java中SQL查询的结果数量:

querySql.append("SELECT COUNT(csp.id) as total FROM child_subscription_prices csp ");
// ...

query.findUnique().getLong("total"); // Also 409 !

所以很明显,PhpMyAdmin和EBean中的配置似乎有区别,但我看不出哪一个!

1 个答案:

答案 0 :(得分:0)

有关信息,问题来自这一行:

query.setParameter("poles", StringUtils.join(poleIds.toArray(), ","));

相反,我只需将其替换为:

// poleids is a List<Long>
query.setParameter("poles", poleIds);

一切正常:)