- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在 PostgreSQL 数据库中执行的查询正在正确获取记录。但是,当使用 createnativeQuery 实现时,我收到错误
错误 SqlExceptionHelper:131 - 错误:“:”处或附近存在语法错误
下面提到了在 Postgres 数据库中成功执行的查询
select d.dt::date as date_current,
coalesce(underwriter_daily_cap, daily_file_cap) as file_cap,
user_id
from generate_series(date '2019-04-05', date '2019-04-09', interval '1'
day) as d(dt)
left join (
select upd.*, ud.daily_file_cap
from mod_underwriter_daily_file_count upd
join lsa_assignment_details ud on ud.user_id = upd.user_id
where ud.user_id = 350
) upd on upd.date_current = d.dt::date
ORDER BY d.dt DESC;
DAO层代码如下
@SuppressWarnings("unchecked")
public List<Object[]> getUnderWriterCap(String dynamicUserId) {
log.info("Entered UserSkillMappingHibDAO :
getUnderWriterCap");
Session session = sessionFactory.getCurrentSession();
Date currentDateMinusFive =
DateUtil.getLastFiveDayOldPSTDate();
Date currentDate = DateUtil.getCurrentPSTDate();
String queryString = " select d.dt::date as date_current,
coalesce(underwriter_daily_cap, daily_file_cap) as file_cap, user_id "
+" from generate_series ( date '"+DateUtil.getDateFormat(currentDateMinusFive)+"', date '"+DateUtil.getDateFormat(currentDate)+"', INTERVAL '1' DAY ) as d(dt) "
+" left join ( select upd.*, ud.daily_file_cap from mod_underwriter_daily_file_count upd "
+" join lsa_assignment_details ud on ud.user_id = upd.user_id where ud.user_id = "+ dynamicUserId
+") upd on upd.date_current = d.dt::date ORDER BY d.dt DESC " ;
List<Object[]> records = session.createNativeQuery(queryString)
.getResultList();
return records;
}
执行上述代码时控制台出现异常如下
hibernate :选择 d.dt:date 作为 date_current,coalesce(underwriter_daily_cap, daily_file_cap) 作为 file_cap,user_id fromgenerate_series (date '2019-04-04', date '2019-04-09', INTERVAL '1' DAY) as d(dt) left join ( select upd.*, ud.daily_file_cap from mod_under writer_daily_file_count upd join lsa_assignment_details ud on ud.user_id = upd.user_id where ud.user_id = 403) upd on upd.date_current = d.dt:date ORDER BY d.dt DESC2019-04-09 18:58 错误 SqlExceptionHelper:131 - 错误:“:”处或附近的语法错误 位置:14
最佳答案
这里有几个错误。比语法错误更重要的是如何将参数作为字符串文字附加。
而不是:
session.createNativeQuery("select * from tbl where param = '" + value + "'");
您必须使用准备好的语句(即要查找的术语)。这对于安全性极其重要。
Query q = session.createNativeQuery("select * from tbl where param = :par1");
q.setParameter("par1", value);
现在至于语法错误,这是由于您使用 PostgreSQL 的自定义类型转换语法引起的。您必须将其替换为从 d.dt::date
到 cast(d.dt as date)
的标准 SQL 类型转换,因为 Hibernate 期望 :
作为命名参数的开头。
String queryString = "select cast(d.dt as date) as date_current, "
+" coalesce(underwriter_daily_cap, daily_file_cap) as file_cap, user_id "
+" from generate_series ( current_date - 5, current_date, INTERVAL '1' DAY ) as d(dt) "
+" left join ( select upd.*, ud.daily_file_cap from mod_underwriter_daily_file_count upd "
+" join lsa_assignment_details ud on ud.user_id = upd.user_id where ud.user_id = :dynuid ) upd on upd.date_current = cast(d.dt as date) ORDER BY d.dt DESC " ;
List<Object[]> records = session.createNativeQuery(queryString)
.setParameter("dynuid", dynamicUserId)
.getResultList();
我还用数据库函数替换了您当前的日期 java 计算。而不是这样做:
Date currentDateMinusFive = DateUtil.getLastFiveDayOldPSTDate();
Date currentDate = DateUtil.getCurrentPSTDate();
...
.setParameter("ds", DateUtil.getDateFormat(currentDateMinusFive))
.setParameter("de", DateUtil.getDateFormat(currentDate))
您可以让数据库使用 current_date - 5
和 current_date
为您完成此操作。
您应该注意的另一件事是,由于您的 DateUtil 使用旧的 java.util.Date 类和相关内容,如果您使用 SimpleDateFormatter 对其进行格式化,那么每次调用时它都必须是一个新实例。不要将其优化为静态最终,因为它不是线程安全的。我就受过这个苦。
编辑:我也相信您的查询可以进一步优化,并且会产生相同的结果:
select upd.date_current, underwriter_daily_cap, daily_file_cap from mod_underwriter_daily_file_count upd
join lsa_assignment_details ud on ud.user_id = upd.user_id
where ud.user_id = :dynuid and
upd.date_current between current_date - 5 and current_date
ORDER BY d.dt DESC
请注意,我从选择中删除了一些字段,例如 user_id,因为您已经告诉数据库您想要哪个字段。一个主要区别是此查询将跳过没有条目的几天的结果。
关于java - 在 createNativeQuery 中使用generate_series时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55594338/
我有以下内容,其中包含一个 NativeQuery,我需要在其中设置参数,但有些事情是错误的,因为未设置参数,因此查询是 SELECT movieId, title, genres FROM movi
我有一个使用 EntityManager.createNativeQuery 的应用程序。我们的质量门(Sonar)对此不太满意,并且由于 SQL 注入(inject)的风险而向我显示了一个严重错误。
EntityManager em = OpenJPAUtils.openEntityManager(); String sql="select DISTINCT student.studentId f
如何使用 createNativeQuery 编写 IN 子句? 示例 codeList = "123 ,456"; 然后我得到这样的codeList: CODE IN (:codeList) 但是我
tl;博士 我有一个有效的 SQL 查询,它从 SQL 命令行返回行,但通过 Doctrine 提交时则不会。我认为问题在于我如何设置ResultSetMapper。我读过docs关于 native
我正在使用以下代码通过 hibernate 执行 native SQL 查询: Query zonesQuery = session.createNativeQuery( "S
我在我的项目中使用 Hibernate 和 JPA。我使用下面的代码返回对象列表,但当我在 mysql 中使用 sql 时它返回空列表,它工作正常。 Query query=entityManager
我在 Hibernate 中有一个简单的查找方法: @Override public TblUser findByUsername(String username) { return (Tbl
我正在尝试使用 createNativeQuery 从数据库获取结果集并将其映射到实体对象列表。 当我这样做的时候 List results = this.em.createNativeQuery(q
我需要使用entityManager选择 native 查询。我找到了方法: public Query createNativeQuery(String sqlString, Class result
我尝试使用 Doctrine 选择一百万行,但遇到了一些问题。 首先我尝试使用 ORM 查询来完成此操作,但后来我发现 native 查询更快。(我不需要为此使用 ORM 映射)。 我已经在使用数组水
我在数据库中加入了 2 个具有外键关系的实体,但在代码中没有(将原因留到另一个问题): em.createNativeQuery("SELECT u.* FROM user u JOIN user_c
我们最近将一个项目从使用 Hibernate 4 更新为 Hibernate 5.2,随之而来的是需要更新我们所有的标准以使用 JPA。大多数情况下一切正常,但我有一个查询不再运行。我们正在查询的表上
我想根据一个字段(类型)的值从两个不同的表中检索数据。基本上,如果类型是 2 或 3,则将“subcategory_id”分别关联到类别 2 或类别 3 普通 SQL: SELECT s.id, s.
在 PostgreSQL 数据库中执行的查询正在正确获取记录。但是,当使用 createnativeQuery 实现时,我收到错误 错误 SqlExceptionHelper:131 - 错误:“:”
我想在 entityManager 中使用 createNativeQuery 运行一个 Update 查询。我无法运行它。 我的类(class)结构: class ABC_DAO { List =
使用Java, hibernate 。 我有一个查询 String pixIds = "1,2,3"; String query = "SELECT * FROM comment WHERE PIX_
createNamedNativeQuery 和 createNativeQuery 之间是否有任何与性能相关的特性,因为我们计划对 HQL 查询使用命名查询,并为原生 SQL 查询维护单独的查询文件
EclipseLink 的奇怪行为(Eclipse Persistence Services - 2.1.1.v20100817-r8050),我有一个 false(虚拟/不是数据库中的实际表)实体类
乍一看我有一个简单的问题: entityManager() .createNativeQuery("select count(*) as total, select sum(field) as tot
我是一名优秀的程序员,十分优秀!