MySQL 查询字符串的个数

今天碰到需求,要查某个字段中值为Y的个数(值只有Y和N),当值只有0和1的情况下,我只需要统计总和便可以算出总和了,但字符串的情况下折腾了好久,最后找到了两个办法:

  1. 采用count函数,当值符合便统计,不符合写入null
    SELECT
    count( is_free = 'Y' OR NULL ) 
    FROM
    `scada_equipment_status'

    这种方法当符合的时候便会被count函数统计到,当不符合count统计到null

  2. 采用sum函数,当值符合的时候返回1,不符合返回0
    SELECT
    sum( is_free = 'Y' ) 
    FROM
    `scada_equipment_status`

    这个方法判断是否符合返回0或者1,再将其相加便得到了符合条件的数目
    希望能帮助到大家

本作品采用《CC 协议》,转载必须注明作者和本文链接
CodeFarmer
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!