如果 sql 中针对 int(11) 的字段进行了函数操作,jdbc 为了防止数值溢出,会将 Integer 转成 Long 型,例如: 1:假定有个收入金额字段 int(11) income 2:select income from xxx 这类查询不会将 int 升级为 long 3:select sum(income) form xxx 这类查询计算所有 income 字段的总和,就很可以有造成数值溢出,所以安全起见 jdbc 会自动升为 Long 型 4:整个类型升级过程 jfinal 并未干预过,完全交由 JDBC 自动完成 此外,类似 count(x) 这样的函数也会有这样的行为
1:假定有个收入金额字段 int(11) income
2:select income from xxx 这类查询不会将 int 升级为 long
3:select sum(income) form xxx 这类查询计算所有 income 字段的总和,就很可以有造成数值溢出,所以安全起见 jdbc 会自动升为 Long 型
4:整个类型升级过程 jfinal 并未干预过,完全交由 JDBC 自动完成
此外,类似 count(x) 这样的函数也会有这样的行为