sql中status字段是nvarchar 128,另外一个status字段是nvarchar 16。为什么select * from table where status in ("正常","冻结")第二个status可以查出,第一个查出来为空值
时间: 2024-02-15 11:01:46 浏览: 91
MySQL查询空字段或非空字段(is null和not null)
可能是因为第一个status字段中存储的字符串的长度超过了16个字符,导致无法匹配到"正常"和"冻结"这两个字符串。请尝试使用以下SQL语句来查询第一个status字段中的值是否包含"正常"和"冻结"这两个字符串:
```
SELECT * FROM table WHERE status LIKE '%正常%' OR status LIKE '%冻结%'
```
如果查询结果中包含了符合条件的记录,那么说明第一个status字段中存储的确实是超过16个字符的字符串。此时,您可以考虑修改第一个status字段的类型,将其改为nvarchar 256或更大的长度,以便能够存储更长的字符串。
阅读全文