我该如何解决这个问题?
where someNtext IN ('asd',asd1')
给出错误:
消息 402,第 16 层,状态 1,第 XXXXX 行
数据类型 ntext 和 varchar 在等于运算符中不兼容。
An IN
list 只是 OR 条件的简写。这LIKE
条款适用于NTEXT
and TEXT
字段。因此,您可以结合这两个想法来做到这一点:
WHERE (
someNtext LIKE N'asd'
OR someNtext LIKE N'asd1'
)
然而,正如 @marc_s 在对该问题的评论中所建议的那样,NVARCHAR(MAX)
是首选,因为所有字符串函数都可以使用它(并且TEXT
, NTEXT
, and IMAGE
从 SQL Server 2005 开始,数据类型已被弃用)。你could进行内联转换,例如:
WHERE CONVERT(NVARCHAR(MAX), someNtext) IN (N'asd', N'asd1')
但可能效果不如使用LIKE
条款与OR
状况。
请注意:当与NTEXT
/ NVARCHAR
/ NCHAR
/ XML
数据,最好是always字符串文字带有大写“N”前缀。如果不这样做,可能会导致与数据库默认排序规则关联的代码页不支持的任何字符的数据丢失。
有关在 SQL Server 中一般使用排序规则/编码/Unicode/字符串的更多信息,请访问:https://Collations.Info/ https://Collations.Info/
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)