假设我有一个名为citilities的表,其中包含以下字段和值:
| ID | Name | Age |
|----|:------:|---: |
| 1 | King | 60 |
| 2 | Queen | 50 |
| 3 | Prince | 25 |
如果我想显示年龄在“50到100”之间的公民和其他年龄在“5到30”之间的公民,我可以使用这样一个简单的where条件:
SELECT * FROM Citizens WHERE (Age BETWEEN 5 AND 30 ) OR (Age BETWEEN 50 AND 100 );
但是,问题来了:如何在符合条件的每一行旁边显示最小和最大请求的年龄来获得这样的结果?
| ID | Name | Age |INTERVAL|
|----|:------:|:---:|-------:|
| 1 | King | 60 | 50-100 |
| 2 | Queen | 50 | 50-100 |
| 3 | Prince | 25 | 5-30 |
2条答案
按热度按时间bjg7j2ky1#
你需要一个
CASE
表达式:注意:我不确定您是否只想显示特定的年龄范围。如果是的话,那就留下你现在的工作
WHERE
条款完好无损。如果要包含所有数据,请删除WHERE
条款。在这种情况下,不匹配的范围将报告为OTHER
.另一种可能扩展得更好的方法是使用间隔表:
然后连接到此表以引入间隔标签:
第二种方法的一个主要优点是,它可能引入指数策略。
8yparm6h2#
我会用一个
CASE
声明: