检查Postgres sql语句中值是否为空或空字符串的最佳方法是什么?

Value可以是一个很长的表达式,所以在检查时最好只写一次。

目前我正在使用:

coalesce( trim(stringexpression),'')=''

但是看起来有点丑。

Stringexpression可以是char(n)列,也可以是包含char(n)列的表达式,后面带空格。

最好的方法是什么?


当前回答

另一种方法是

nullif(trim(stringExpression),'') is not null

其他回答

另一种方法是

nullif(trim(stringExpression),'') is not null

检查字符串的长度也是有效的,并且是紧凑的:

where length(stringexpression) > 0;

很多答案都是最短的,但不一定是最好的如果列中有很多空。分解检查可以让优化器更快地计算检查,因为它不需要在其他条件上工作。

(stringexpression IS NOT NULL AND trim(stringexpression) != '')

字符串比较不需要计算,因为第一个条件是假的。

检查是否为空:

coalesce(string, '') = ''

检查null, empty和空格(修剪字符串)

coalesce(TRIM(string), '') = ''

如果数据库有大量的记录,那么空检查会花费更多的时间 你可以用不同的方式使用空检查,比如: 1)其中columnname为空 2)如果不存在() 3) WHERE(当columnname为null时,则为true结束)