2019-10-26 17:15
补充,由于 SqlPara 中的 sql + para 可以用于大多数 jfinal 的数据库 API,所以 jfinal 添加了直接接受 SqlPara 类型的 API,例如:
Db.find(sqlPara);
实际使用的时候一般这样:
Kv kv = Kv.by("id", 123);
Db.find( Db.getSqlPara("test", kv));
为了进一步节省代码量,jfinal 后来的版本为了进一步消除 Db.getSqlPara() 的使用,又添加了 template 方法,用法:
Db.template("test", kv).find();
具体多看看文档:
https://www.jfinal.com/doc/5-13
2019-10-26 17:10
@柳志龙 使用 #p 与 ? 生成的最终 sql 是完全一样的,区别在于:
#p 指令在生成问号的同时,会向 SqlPara 对象中的 List paraList 中追加生成的问号所对应的参数值
也就是说 #p 指令能处理参数
例如如下的 sql 模板:
#sql("test")
select * from t where id = #p(id)
#end
java 代码获取:
SqlPara sqlPara = Db.getSqlPara("test", Kv.by("id", 123));
String sql = sqlPara.getSql();
Object[] para = sqlPara.getPara();
上面的代码中,变量 sql 的值为:
select * from t where id = ?
也就是说 #p 指令处永远是生成一个问号
para 中的值为数组:[123]
上面的 sqlPara 对象,可以用于 jfinal 的一系列的数据库操作 API,例如:
Db.find(sqlPara.getSql(), sqlPara.getPara())
因为jfinal 的数据库 API 在设计上都是 String sql + Object para[] 的形式
2019-10-25 19:57
@tuxming 建立对象池,让对象用完以后可以回收,下次需要用的时候不用重新申请内存,而是从池里面取用
当然,池中的对象多少要控制好,不让无限制增长
2019-10-25 19:01
@tuxming 内存占用突发性增大挺危险,因为 JVM 的垃圾回收本身就有延迟问题
想办法控制内存占用的速度小于回收的速度
2019-10-25 17:09
@hb963724769 按照提示来,如果某个类的对象需要放缓存,让其实现一下 Serializable 接口即可,这个是 java 基础,与 jfinal 是无关的