首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

一个带逻辑判断的sql话语

2012-08-08 
一个带逻辑判断的sql语句遇到一个问题,是这样的:我有两张表,消息表和消息回复表。消息回复表里存在消息表的

一个带逻辑判断的sql语句
遇到一个问题,是这样的:
我有两张表,消息表和消息回复表。消息回复表里存在消息表的主键作为其外键。现在我查询消息表的时候想得到此消息是否有回复,如何实现 (注:在消息表里并没有是否回复的字段 )。

应用到的SQL的语法是,直接在某个字段上应用

casewhen (根据消息ID查询回复数量) > 0 then 有回复else 无回复end

如:
SELECT CASEWHEN(SELECT COUNT(*) FROM MESSAGE_REPLY mr WHERE m.message_id=mr.message_id)>0THEN 1 ELSE 2ENDAS "是否回复"FROM MESSAGE m 

对于SQL语句的理解,可以从标准SQL的解析顺序上去理解。
标准SQL的解析顺序为:
1.FROM CLAUSE
2.WHERE...
3.GROUP BY..
4.使用聚合函数进行计算
5.HAVING...
6.SELECT...
7.ORDER BY...

热点排行