如何在select语句中编写if条件?

时间:2011-04-18 22:54:26

标签: sql select if-statement conditional-statements

我有一个列需要填充ture / false /(N / A)数据。此列是select语句的一部分 那么,我怎样才能做到这一点?

SELECT distinct 
program_id, 
prog_name,
Eitc_Active_Switch as Prog_Status,
progmap.client_id,
progmap.ORG_ID,
sec.calwinexists_ind as interface,
sec.Client_name
FROM ref_programs prog (nolock)
LEFT OUTER JOIN ref_county_program_map progmap (nolock)         
ON progmap.program_id=prog.prog_id AND progmap.CLIENT_ID=prog.CLIENT_ID 
INNER join sec_clients sec (nolock)
on sec.client_id=progmap.Client_id

'sec.calwinexists_ind as interface'是列。只应显示三个记录(AMC,AMBD,ACMNI)和'N / A'的真/假 其余的记录

任何人都可以帮助我吗?

2 个答案:

答案 0 :(得分:25)

您应该使用CASE表达式。

示例:

SELECT name,salary,
CASE    
WHEN  salary <= 2000 THEN 'low'
WHEN  salary > 2000 AND salary <= 3000 THEN 'average'
WHEN  salary > 3000 THEN 'high'
END AS salary_level
FROM employees
ORDER BY salary ASC

通过这种方式,您应该调整查询以满足您的需求。

答案 1 :(得分:1)

你能使用CASE WHEN控制吗?看看:http://dev.mysql.com/doc/refman/4.1/pt/control-flow-functions.html