sql利用在一条语句中count出不同的条件的值,

【对原作者的补充】
在这里插入图片描述
使用了以下SQL语句:

select COUNT(if(w.isqualified=0,true,null) as aaa from table where 条件 group by w.isqualified;

在navicat中运行没有问题,但是在Java中使用该sql去数据库查询数据时,出错了!问题:org.springframework.dao.InvalidDataAccessApiUsageException: org.hibernate.hql.internal.ast.QuerySyntaxException: expecting CLOSE, found '(' near line 1, column 81 [select COUNT(if(w.isqualified=0,true,null))........]

该问题或许是 对嵌套括号解析混乱导致。
后将sql语句改为

select COUNT(case when w.isqualified=0 then w.isqualified end) as aaa from table where 条件 group by w.isqualified;

解决办法:使用count(case when(条件) then 列名 end) as mycount,可以避免括号解析混乱的问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值