java代码:
@Override
public int selectUserAll() {
return (int)getSqlMapClientTemplate().queryForObject(
"lz_user.ibatorgenerated_selectCount");
}
sql:
<select id="ibatorgenerated_selectCount" resultClass="int">
select count(*)
FROM lz_user user,
lz_user_info userinfo,
lz_user_vip userVip
</select>
返回值:
DEBUG 2016-08-04 10:02:00 [java.sql.Connection] - {conn-100003} Connection
DEBUG 2016-08-04 10:02:00 [java.sql.Connection] - {conn-100003} Preparing Statement: select count(*) FROM lz_user user, lz_user_info userinfo, lz_user_vip userVip
DEBUG 2016-08-04 10:02:00 [java.sql.PreparedStatement] - {pstm-100004} Executing Statement: select count(*) FROM lz_user user, lz_user_info userinfo, lz_user_vip userVip
DEBUG 2016-08-04 10:02:00 [java.sql.PreparedStatement] - {pstm-100004} Parameters: []
DEBUG 2016-08-04 10:02:00 [java.sql.PreparedStatement] - {pstm-100004} Types: []
DEBUG 2016-08-04 10:02:00 [java.sql.ResultSet] - {rset-100005} ResultSet
拜求,这个是怎么回事儿,谢谢。
mapper.xml中配置 返回int类型 。这样直接
<select id="getCount" resultType="long">
select count(*) from 表
</select>
猜测:返回类型用map试一下。
我平常用mybatis时,count的返回类型一般是BigDecimal型的。
从这条信息来看,返回的可能不是int:
DEBUG 2016-08-04 10:02:00 [java.sql.ResultSet] - {rset-100005} ResultSet