- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我编写了以下 mysql 查询
select g.*, (case when count(sg.seriesid) > 0 then 1 else 0 end) as checked
from genre g
join seriesgenre sg on sg.genreid = g.id and sg.seriesid = 1;
查询结果为null |空 | 0
有没有办法可以避免在不满足连接条件时返回任何结果?
编辑:
意识到该查询仅返回一个行结果。我想要的结果集是列出所有流派,并用一列指示特定系列是否具有该流派。 (上面使用的指标是0,1)
最佳答案
您可以在查询末尾添加 HAVING 子句,例如
HAVING checked > 0
请注意,由于查询中没有 GROUP BY
子句,因此查询最多将返回一行。这是一个有效的 SQL 语句,但它返回一个奇怪的结果,因为该结果集满足的是一个非常不寻常的用例。
(删除 COUNT() 聚合也会阻止返回一行,但该语句也可能返回多行。尚不完全清楚您想要返回什么结果集。)
<小时/>跟进
问:我想要的结果是列出所有可用的类型,并用一列指示特定系列是否具有该类型。
答:但这与 OP 查询返回的结果完全不同。
对于这样的结果,使用 JOIN 操作返回流派中的“所有”行(假设流派中有一列或列的组合是唯一的)的通常模式是:
SELECT g.id
, g.foo
, sg.genreid IS NULL AS checked
FROM genre g
LEFT
JOIN seriesgenre sg
ON sg.genreid = g.id
AND sg.seriesid = 1
GROUP
BY g.id
, g.foo
如果 id
在 genre
表中是唯一的,则可以从 GROUP BY
中省略 g.foo
> 条款。这是正常的模式。
如果您想忽略 genre
中在系列流派中没有匹配行的行,则只需删除 LEFT
关键字即可使连接操作成为“内部连接” “连接而不是“外部”连接。
如果保证(genreid,seriesid)
元组是唯一的,我们可以消除GROUP BY
子句,因为我们可以保证JOIN操作将从系列流派表中最多返回一个匹配行,例如
SELECT g.id
, g.foo
, sg.genreid IS NULL AS checked
FROM genre g
LEFT
JOIN seriesgenre sg
ON sg.genreid = g.id
AND sg.seriesid = 1
<小时/>
在更一般的情况下,如果id
在genre
中不是唯一的,或者没有一组列可以在genre
中构成一行唯一,那么我们需要避免使用 GROUP BY
子句折叠行,并使用相关子查询而不是 JOIN 操作:
SELECT g.id
, g.foo
, IFNULL( SELECT 1
FROM seriesgenre sg
WHERE sg.genreid = g.id
AND sg.seriesid = 1
LIMIT 1
),0) AS checked
FROM genre g
如果我们想要排除 seriesgenre
中没有匹配行的行,请再次使用相关子查询:
SELECT g.id
, g.foo
, ( SELECT 1
FROM seriesgenre sg
WHERE sg.genreid = g.id
AND sg.seriesid = 1
LIMIT 1
) AS checked
FROM genre g
HAVING checked = 1
关于mysql 连接带有指示列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25727625/
我正在尝试复兴使用3DNow的旧Win32游戏!指令集以进行3D渲染。 在Win7-Win10等现代OS上,不允许FPADD或FPMUL之类的Win10指令,并且该程序将引发异常。 自3DNow数量!
我坐在机场这里,想出了一些我想尝试的东西,但如果 macports 下载-编译-下载-编译,我没有时间 sudo port install .但是,如果它下载了所有内容,那么我就可以在飞机上对其进行编
我使用的是 Jackson 库,而不是 2.6.3。我想在类中定义序列化方法,并且我想指示 Jackson 在序列化对象时调用此方法。 例如 public interface AClass { d
我正在制作一个自动目录,一切正常。我只需要将顶部标题指定为“粗体” jQuery(document).ready(function(){ var ToC = "" + ""; var ne
我要设置 html 对象的属性。 var property1 = 'style.visibility'; var property2 = 'style.display'; var property3
在 boost::spirit::traits::transform_attribute 中指示解析失败的正确方法是什么?我可以抛出任何旧的异常,还是它要我做的特定事情? namespace boos
我正在使用 XmlPullParser 在移动设备上通过 http 逐渐加载一些数据。 由于此类连接的速度通常可以低至 1KB/s 或更低,我想降低 PullParser 的默认缓冲区大小 8096
我正在尝试集体检查数据是否存在于各个表中。我有一个主表 A 和包含与 A 相关的数据的各种表 - 称它们为表 B、C 和 D。我想编写一个查询,对于 A 中的每个条目,指示是否有任何行在 B、C 和
当您使用 Cargo 和 rustdoc 为 Rust crate 生成文档时,我在生成的页面中看不到任何指示它适用于哪个版本的 crate。例如,看看 the log crate's documen
我有一个 CS 类,它表示 3D 坐标系,即 (x, y, z) class CS { private: double x; double y; d
我有一个用 Wordpress 制作的项目。我有在社交网络上分享的帖子。在推特上没有问题,因为我创建的推文没有图片。Facebook 允许我从要分享的链接中选择页面图像。但是 Google+ 正在挑选
问题 如何在 Scrapy 中忽略响应的内容长度? 解释 考虑这个 curl 命令" curl -u http://data.icecat.biz/export/level4/NL/files.in
我有一个测试程序,如果它可以依赖于在 Windows 上以严格的优先级顺序安排的线程,它会简单得多。我看到一个低优先级线程与高优先级线程一起运行,我想知道这是不是因为不同的线程被安排在不同的处理器内核
我正在使用 getUserMedia 函数从网络摄像头录制视频。一切正常,除了它仅以 640x480 分辨率录制,当我刚刚指定 video: true 作为约束时。 如果我按如下方式设置约束,我现在可
我有一个简单的类定义如下: class Model { constructor(props?:{}) { _extend(props, this); } } 其中构造函数接受一个对象作
我第一次在 Visual Studio 2010 beta 2 中使用 .net-4.0 中的 System.ComponentModel.Composition 试用托管扩展框架。 我一直无法让 C
我正在使用 System.CodeDom 功能在运行时编译代码,我想知道我是否可以指定一个编译器参数或其他解决方法来以英语语言显示编译器错误,而不是使用系统的默认语言语言。 但是,在 MSDN 文档中
我正在使用 XmlWriterSettings 将 Xml 写入文件。我有只有属性的元素,没有 child 。我希望它们输出为: 代替 我可以使用 XmlWriterSettings 来实现吗?
我在 sbt 中创建了一个多项目构建。这是 build.sbt 在主目录中: lazy val root = project in file(".") aggregate(data, reco, re
这里我有一个程序,可以计算一个人不同的日常事件,例如他一周踢足球的次数等。这里我有一个 switch 语句,可以计算不同事件的值。我强制这个对象指示 sort() 函数内的 dayEvents 对象。
我是一名优秀的程序员,十分优秀!