ISNULL 用法
在 SQL Server 中,ISNULL 函数只接受两个参数,不支持三个参数的情况。
错误写法示例:
ISNULL(t11.ItemCode,'Y','N')
ISNULL 函数的正确语法是:
ISNULL(check_expression, replacement_value)
CASE WHEN 用法
如果需要实现类似三目运算符的功能(当字段为 NULL 时返回 'Y',否则返回 'N'),可以使用 CASE WHEN 表达式:
CASE WHEN t11.ItemCode IS NULL THEN 'Y' ELSE 'N' END
IIF
或者使用更简洁的 IIF 函数(SQL Server 2012 及以上版本支持):
IIF(t11.ItemCode IS NULL, 'Y', 'N')
查询小技巧
技巧一:使用 CONCAT 安全地拼接字符串
问题: 传统的用加号 + 拼接字符串时,如果任何一个字段为 NULL,整个结果都会变成 NULL。
旧方法(有风险):
SELECT FirstName + ' ' + LastName AS FullName FROM Employees;
小技巧(使用 CONCAT):
SELECT CONCAT(FirstName, ' ', LastName) AS FullName FROM Employees;
好处:
CONCAT函数会自动将NULL值视为空字符串''来处理。- 即使
FirstName或 为 NULL,其他部分依然会正常拼接,最终结果不会是 NULL。


