jfinal 分页排序bug
@JFinal 你好,想跟你请教个问题:
SELECT * FROM T ORDER BY length(id)
分页时出错,源代码
public static String replaceFormatSqlOrderBy(String sql) {
sql = sql.replaceAll("(\s)+", " ");
int index = sql.toLowerCase().lastIndexOf("order by");
if (index > sql.toLowerCase().lastIndexOf(")")) {
String sql1 = sql.substring(0, index);
String sql2 = sql.substring(index);
sql2 = sql2.replaceAll("[oO][rR][dD][eE][rR] [bB][yY] [u4e00-u9fa5a-zA-Z0-9_.]+((\s)+(([dD][eE][sS][cC])|([aA][sS][cC])))?(( )*,( )*[u4e00-u9fa5a-zA-Z0-9_.]+(( )+(([dD][eE][sS][cC])|([aA][sS][cC])))?)*", "");
return sql1 + sql2;
}
return sql;
}
查询总记录数的sql将为:select count(*) from t order by length(id)
不知道2.2是否已修复此bug
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(6)
用这种不严谨的做法(可能不需要完美的比如分析sql,构建语法树那些),建议注释和文档里写得足够清楚可能的缺陷
回复
@乌龟壳 : 去除了处理 order by 的正则以后,就很严谨了
回复
@JFinal : bingo
用一下 jfinal 3.0,该版本没有用正则处理过 order by,所以是正确的
2.2没问题 但是3.0却又出来了。@jfinal
m