MYSQL:如果另一列等于其他内容,则为count列
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MYSQL:如果另一列等于其他内容,则为count列,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1195字,纯文字阅读大概需要2分钟。
内容图文
我有下表:
----------------------------------------------
|ID|Vote_Item_ID|User_ID|Country_code| Vote|
|01| 105102151|user1 | CA| like|
|02| 105102151|user2 | CA|dislike|
|03| 105102151|user3 | UK|dislike|
|04| 105102151|user4 | UK| like|
|05| 105102151|user5 | UK| like|
----------------------------------------------
我需要做的是创建一个SQL语句,创建一个数组,总结每个国家的好恶……我使用它的脚本有175个国家,那么这是一个效率低下的方法吗?
我不确定如何编写Select语句,因为我希望脚本可以重用于许多不同的“vote_item_id”
顺便说一下,我正在使用带有MYSQL数据库的PDO.
谢谢
解决方法:
SELECT Country_Code,
SUM(CASE WHEN vote = 'like' THEN 1 ELSE 0 END) `like`,
SUM(CASE WHEN vote = 'dislike' THEN 1 ELSE 0 END) dislike
FROM tableName
GROUP BY Country_Code
或者如果你想要PreparedStatement(两者都给出相同的结果)
SET @sql = NULL;
SELECT
GROUP_CONCAT(DISTINCT
CONCAT(
'SUM(CASE WHEN vote = ''',
Vote,
''' then 1 Else 0 end) AS `',
Vote, '`'
)
) INTO @sql
FROM TableName;
SET @sql = CONCAT('SELECT Country_Code, ', @sql, '
FROM tableName
GROUP BY Country_Code');
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
内容总结
以上是互联网集市为您收集整理的MYSQL:如果另一列等于其他内容,则为count列全部内容,希望文章能够帮你解决MYSQL:如果另一列等于其他内容,则为count列所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。