mysql – 根据另一个表中记录的存在将列添加到select语句
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql – 根据另一个表中记录的存在将列添加到select语句,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1439字,纯文字阅读大概需要3分钟。
内容图文
![mysql – 根据另一个表中记录的存在将列添加到select语句](/upload/InfoBanner/zyjiaocheng/907/af23cfee4ed1415bb519ee7b882846c7.jpg)
我正在编写一个SQL查询,我想在记录集中添加一个列,该列的值基于另一个表中记录的存在.我有一个左连接加入表,我假设我必须在我的SQL中做一些转轴,但我不熟悉表转动.
我现有的SQL是
SELECT tabs.name,tabs.id AS tabid,tabs.sort,fields.id AS fieldid, fields.label
FROM tabs
INNER JOIN fields
ON tabs.id = fields.tabid
LEFT JOIN fields_reports
ON fields_reports.fieldid = fields.id
WHERE fields_reports.reportid = 57
GROUP BY fields.id
ORDER BY tabs.sort, fields.id
在SQL中发生的是它拉取字段(这是语句的核心)和选项卡(它们是essentailly类别). fields_reports表将字段映射到我正在构建的报表.
我需要做的是在我的语句中添加一个列:如果当前字段在fields_reports表中有记录,并且传入了报告号(57),则将列值赋值为1,否则为0.
编辑:我的查询有另一个问题.现在查询只是拉动附加到一个报告的字段.有没有一种方法,我可以做一个子查询从fields_reports表中选择,以便我可以拉所有字段,然后将列附加到报告?
这是现在提取记录的查询,但只提取一个报告字段
SELECT tabs.name,tabs.id AS tabid,tabs.sort,fields.id AS fieldid, fields.label,
CASE WHEN fields_reports.id IS null THEN 0 ELSE 1 END AS inReport
FROM fields
INNER JOIN tabs
ON tabs.id = fields.tabid
LEFT JOIN fields_reports
ON fields_reports.fieldid = fields.id
WHERE fields_reports.reportid = 57
GROUP BY fields.id
ORDER BY tabs.sort, fields.id
如果我应该为此开辟一个新问题,请告诉我.
解决方法:
You can `SELECT ..., IF(field_reports.reportid=57),1,0), ... FROM ...`
编辑需要删除WHERE子句中的reportid测试,否则这作为解决方案没有多大意义. (感谢@Dave Long.)
内容总结
以上是互联网集市为您收集整理的mysql – 根据另一个表中记录的存在将列添加到select语句全部内容,希望文章能够帮你解决mysql – 根据另一个表中记录的存在将列添加到select语句所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。