jfinal 分页排序bug? 400 报错
@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
m######
2.2没问题 但是3.0却又出来了。@jfinal
######用一下 jfinal 3.0,该版本没有用正则处理过 order by,所以是正确的
######回复 @JFinal : bingo######回复 @乌龟壳 : 去除了处理 order by 的正则以后,就很严谨了######用这种不严谨的做法(可能不需要完美的比如分析sql,构建语法树那些),建议注释和文档里写得足够清楚可能的缺陷版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。