2017-01-03 15:31
在多数情况下,findAll() 这种方式不是 jfinal 提倡使用的 api,jfinal 提倡 select 具体的字段,可以养成更好的习惯,而且无条件查询表中所有数据的情况并不是经常发生,即便有这种需求,也可以通过 find("select * from t") 来实现,这种实现方式不仅代码量并没有提升,而且开发者自己明确自己是否真的需要无条件 select * 查询当前表中所有数据
而对于 findFrist(searchEntity) ,jfinal 并不是很容易地确定该怎么去利用 searchEntity 中的查询条件,例如:是利用其中的所有条件? 还是利用部分条件? 是某个条件用 and 还是某些条件用 or 和 not?还是用 not exists 和 in?
查询条件的多少与利用方式是一个极其个性化、业务化的事情,如果 jfinal 去插手这个事情,事情可能变得更糟糕,并且更加复杂。所以对于这个问题,jfinal 是开放 String sql 与 Object... sql,这两个参数来让用户自由去发挥,无招往往才是最好的招
当然,为了方便用户更加方便和灵活的定制 sql,目前的 jfinal 版本还做得不够,这正是即将推出的 jfinal 新版本要做的事情,多多关注社区动态,近期发布新版本
2017-01-03 11:46
@sdfsf 以下这几个链接中有上千个相关项目,供参考:
http://git.oschina.net/search?search=jfinal&type=project&condition=updated_at
https://www.oschina.net/search?q=jfinal&scope=project&tag1=0&tag2=0&lang=0&os=0
https://github.com/search?o=desc&q=jfinal&s=stars&type=Repositories&utf8=%E2%9C%93
2017-01-02 21:52
@localhost8080 根据日志提示信息,可以猜测一下,可能是连接池在多线程下并发分配资源时造成了死锁,但死锁存在并不一定就是不正常的,检测出死锁,将死锁去除也是一种处理方式。
据日志信息来说这类死锁可能是正常现象,否则就直接报ERROR,而不是WARN
2017-01-01 17:57
@xzquan 返回true 对于 start() 来说是告诉 jfinal 插件启动正常,返回 false则 jfinal 会报出异常,终止项目的启动,这种机制是让插件可以告知 jfinal 是否要终止项目的启动
如果某个插件是一个关键性插件,启动不正常就会影响关键业务,这时让项目无法启动是必要的
类似的 stop 是告知 jfinal 插件停止失败,jfinal 会对此写日志,可通过查看日志知道插件为什么没有停止成功,进而去修正程序
2017-01-01 15:07
start() 与 stop() 方法会别会在 jfinal 启动与停止时被回调,开发插件,只需要实现 IPlugin 接口,在 start() 里面放入希望项目启动时的操作,在 stop() 中放入希望项目停止时的操作即可
除了 Plugin 以外,jfinal 的主要扩展方式有:Controller、Model、Interceptor、Render、Handler,这五个扩展方式相对比较具体,针对于特定需求去扩展,而 IPlugin 就担当起了不确定需求与方向的扩展,因为 jfinal 无法穷尽所有用户需求和场景,而 Plugin 是一个更加抽象化,没有指明具体方向的扩展