代码如下:
sql = " select '--', staff_no from staff where staff_no = ?";
Session session2 = HibernateUtil.getCurrentSession();
Query sqlQuery2 = session2.createSQLQuery(sql);
sqlQuery2.setParameter(0, "04415"); //error in this line
运行时报错
原因:org.hibernate.QueryParameterException:位置超出了声明的序数参数的数量。请记住,序数参数是基于 1 的!职位:1
被抛出,我知道这是由 sql 字符串中的 '--' 引起的,hibernate 将其解释为 sql 注释,
我尝试使用
"select '\\-\\-', staff_no from ...."
这样可以成功运行,但是输出变成\-\-,但是我想要的是--在输出中。
那么如何在hibernate中逃脱'--' createSqlQuery
?
如果我运行,问题是由 select 子句中的“--”引起的
sql = " select '-', staff_no from staff where staff_no = ?";
没有发现问题。