解决:DButils QueryRunner count(*) JavaBean里封装的结果集 返回null 或者返回 0

当你的结果集是一下两种情况时:
化妆品:0
家电:0
服饰:0
化妆品:null
家电:null
服饰:null
你可能出现这个错误:
JavaBean中的字段名与数据库中字段名不一致。
 
我要:使用聚合函数,返回每一个分类里的商品数。下图这种效果。
 
 
 
化妆品 1
家电 3
服饰 1
 
输出:结果集为文章开头那两种。
 
   
   
 
   
   
存在Bug代码:count(*) 改成count(*) as num
   @Test
    public void TestCount(){
//    核心类
        QueryRunner queryRunner = new QueryRunner(getDataSource());
//        Sql
        String sql = "select cname ,count(*) from product inner join category on category_id=cid group by cname;";
//        执行
        try {
//            使用javabean
            List<CountJavaBean> list = queryRunner.query(sql,new BeanListHandler<>(CountJavaBean.class));
            for (CountJavaBean countJavaBean :list){
                System.out.println(countJavaBean);
            }
//            使用MapMapListHandler
//           List<Map<String,Object>> list = queryRunner.query(sql,new MapListHandler());
//            for (Map<String,Object> getKey : list){
//                for(String rsKey : getKey.keySet()){
//                    Object value =  getKey.get(rsKey);
//                    System.out.print(value+"  ");
//                }
//                System.out.println();
//            }

        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
JavaBean:结果集出现null,是因为JavaBean字段num类型设置为Object,而数据库里没有num这个字段,所以只能返回null
	结果集出现0,是因为JavaBean字段num类型设置为int,而数据库里没有num这个字段,所以只能返回0.
package jUnit
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值