jfinal 分页排序bug? 400 报错-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

jfinal 分页排序bug? 400 报错

爱吃鱼的程序员 2020-06-05 12:10:05 64

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

SQL
分享到
取消 提交回答
全部回答(1)
  • 爱吃鱼的程序员
    2020-06-05 12:10:23

    m######

    2.2没问题 但是3.0却又出来了。@jfinal

    ######

    用一下 jfinal 3.0,该版本没有用正则处理过 order by,所以是正确的

    ######回复 @JFinal : bingo######回复 @乌龟壳 : 去除了处理 order by 的正则以后,就很严谨了######用这种不严谨的做法(可能不需要完美的比如分析sql,构建语法树那些),建议注释和文档里写得足够清楚可能的缺陷

    0 0
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

推荐文章
相似问题