2018-07-15 09:47
@lwcompany 如果是 “非maven” ,注意配置一下 Default output folder,这里有配置的方法:
http://www.jfinal.com/doc
maven 项目不需要配置 default output folder
2018-07-14 22:06
@童年 这个问题其实很简单,不要想得那么复杂
1:异常出现在 UserController 第 21 行的 user.setAdress(...)
2:第 21 行的 user 曾经调用过 dao() 方法
3:往前追,user 来自于 users.get(i),再往前 users 来自于 UserService.getUsers()
这个问题就很明显了,你在 UserService.getUsers() 方法中调用过 user.dao() 方法,不要调用这些 user 的 dao() 方法即可
2018-07-14 16:26
@jiren 用 sql 管理就很方便了,例如:
先定义一个函数 genIn , 专用于生成 in 内部的问号与参数
#define genIn(idList)
in(
#for (x : idList)
#(for.first ? "", ",") #para(x)
#end
)
#end
然后在任何地方都可以像这样来使用 genIn() 函数:
#sql("find")
update bx_edums_schedule set is_deleted = '1' where c_id = #para(c_id) and id #@genIn(idList)
#end
java 代码变成这样:
Kv cond = Kv.by("c_id", p_campusId).set("idList", ids);
SqlPara sp = Db.getSqlPara("find", cond);
Db.update(sp);
或者: Db.update(sp.getSql(), sp.getPara());
2018-07-14 15:52
@jiren 有多少个问号就要有多少个参数,此外,你后面的 p_campusld 与 StrKit.join(...) 生成的所有参数应该处于同一个 Object[] 数组里面,不能分开写
你的 StrKit.join(ids,",") 这个代码最终生成的是一个字符串,里面有很多个参数直接放在 in 里面去,否则你的 in 里面就可拼接出同样数量的问号来对应
你这个情况比较复杂,我直接说一下正确的使用结果,假定一共有三个参数:
Object[] paras = new Object[3];
paras[0] = p_campusId;
paras[1] = ids[0];
paras[2] = ids[1];
Db.update("update bx_edums_schedule set is_deleted = '1' where c_id = ? and id in (?, ?)", paras);
注意看上面,问号是三个,参数 paras 数组正好是三个元素。而且特别重要是的 p_campusId 与 ids 这两个参数是要合并到同一个数组中去的,除非你的 ids 不是数组,可以这样:
Db.update("update bx_edums_schedule set is_deleted = '1' where c_id = ? and id in (?, ?)", p_campusId, id1, id2);
如果是数组,可以这样:
Db.update("update bx_edums_schedule set is_deleted = '1' where c_id = ? and id in (?, ?)", p_campusId, ids[0], ids[1]);
这个问题你得明白Java 中的 Object... paras 可变参数规则
2018-07-13 17:25
@请问额qwe 没任何代码,也没任何场景,是断然猜不到是怎么回事的