2016-09-02 10:40
@java180 一定可以的,可能是别的原因造成的,例如eclipse自动编译是否打开,修改的代码是否生效之类的错误
2016-09-02 10:38
@java180 arp.addMapping(...) 的时候指定了 idName 没有? 方法原型是:addMapping(String tableName, String primaryKey, Class> modelClass),注意第二个参数就是主键名称,如果是复合主键就用逗号分隔: "id1, id2"
2016-09-02 10:23
@chenwang 聪明的人解决问题,智慧的人消灭/避免问题,愚蠢的人制造问题。就好比 Hibernate 制造了无数的问题
2016-09-01 15:41
@绝望的八皮 主要看一下这个版本的 changelog: http://www.oschina.net/news/69461/jfinal-2-1-released 注意一下这个 changelog 中谈到的 paginate 方法的改进可以忽略,因为 select 与 sqlExceptSelect 合并的这个改进,在后面的版本中被证实并不好,所以又改回去了
2016-09-01 15:39
@绝望的八皮 更新其实很简单,就是将 jfinal 升级到 2.2,基本上就都是一些改改类名,方法名的事情,将 jfinal 版本号改为 2.2 以后,按照 eclipse、IDEA 错误提示的地方分分钟就改完了
2016-09-01 15:12
@小鑫要宵夜 如果 controller 里面 try catch,只要再接着向上抛出被捕获的异常,拦截器仍然可以收到,如果吃掉异常不抛出来,上层就接收不到了
2016-09-01 15:03
@海哥 假定字段是 int(12),这种情况本身就对应了 jdbc 的 Long 型,难道干预并转换? 其实干预也不难,在生成的 BaseModel 中的 getter 方法中这样 return getNumber(attr).intValue()
2016-09-01 14:35
@小飞象 除了在 sql 使用 sum count 会让 int 升级为 long 以外,还要注意以下升级的情况:
1:int(n) n > 11 的情况
2:int(11),但是是 unsigned 无符号整型的情况
综上,你前面谈到的“表ID字段为转成Long“ 并不是本质原因
做到统一恐怕是不合理的,因为无法兼顾到数值溢出的情况,尤其是 getter、setter 返回值或参数升为 Long 的原因是确实类型就该是 Long
2016-09-01 12:04
@l745230 即便是这样的查询也最终可以追溯到某个字段,因为 select count(1) 是针对这个 sql 得到的第一个字段进行的 count 操作
所以根据后面的 FROM t_intercity_trip c 就可以知道这个 count(1) 是指 t_intercity_trip 表的第一个字段,找到这个字段,看下它的类型就知道原因了