在SQL中,CASE WHEN
语句可以很好地处理NULL值。当你在CASE WHEN
语句中涉及NULL值时,它会根据你的条件返回NULL,除非你明确指定了返回其他值。
以下是一个简单的例子来说明如何处理NULL值:
SELECT id, name, age, CASE WHEN age IS NULL THEN 'Unknown' ELSE age END as age_description FROM people;
在这个例子中,我们有一个people
表,其中有一些人的年龄是NULL。我们使用CASE WHEN
语句来为这些NULL年龄生成一个描述(‘Unknown’)。
注意,在CASE WHEN
语句中,NULL值被视为假值。所以,只有当条件明确返回NULL时,结果才会是NULL。例如:
SELECT id, name, age, CASE WHEN age = 25 THEN 'Young' WHEN age = 35 THEN 'Middle-aged' ELSE 'Old' END as age_group FROM people;
在这个例子中,如果某人的年龄是NULL,那么age_group
列的值也将是NULL,因为NULL不等于25,也不等于35。
总的来说,CASE WHEN
语句可以方便地处理NULL值,你可以根据需要在语句中明确指定如何处理这些NULL值。