2017-11-13 11:08
@iiixxxiii Controller 中的方法已经非常之多了,尽可能不增加,确实有需要的全放在 CPI 这个类之中了
2017-11-13 10:54
@iiixxxiii jfinal 3.3 近期发布,这个版本可以通过 CPI.init(controller , ...) 来调用这个方法
现在你可以通过拦截器来做公共操作,例如 inv.getController().setServletRequest(...) 这样的都可以
2017-11-10 18:06
为了实现性能与功能的平衡,paginate 只支持普通 order by 的替换,而复杂 order by 用一下 paginateByFullSql 这个 API ,具体的用法可以看一下 jfinal 手册第 5.5 章节: 《5.5 paginate 分页支持》
大致原因如下:
1:分页需要生成 sql 去计算当前 sql 的总记录数据,而这个 sql 是不需要 order by 子句的,sql server、oracle 这些数据库甚至不支持 select count 带有 order by 子句,所以 order by 一定要移除
2:由于 sql 语句可以嵌套可以很复杂,如果想用正则表达式非常干净地移除 order by 子句,那么这个正则表达式就要写得非常复杂冗长,比复杂冗长更麻烦的是:经实测这个正则的执行效率会下降一到两个数量级
3:大部分的 order by 是比较简单的,所以为了兼顾性能功能,让 paginate 只支持简单 order by,其它情况用 paginateByFullSql 支持
2017-11-10 17:20
@芦苇 具体代码分享出来啊,在这里贴下代码,说不定很多人需要:jfinal.com/share
2017-11-10 17:02
@simplife 其实不需要手动添加 druidPlugin.start(),而是要 me.add(druidPlugin),否则 jfinal 框架没法回调你的 druidPlugin.start(),就只能自己调用了
2017-11-10 16:08
@miracle佐 指令是区分大小写的,如果希望不区分大小写,可以添加这几个指令的别名指令,例如:
arp.getEngine().addDirective("SQL", new SqlDirective())
只不过这样做只是支持了 sql 的大写指令,而 if for define 这些指令仍然不支持。
这个就跟 java 代码不支持大写的 IF FOR PUBLIC 是一个意思