问题描述
我在连接到 sql Server 2019 数据库的 Microsoft sql Server Management Studio 18 中输入了此查询:
insert into URLs (URL,QuestionID)
values ('⑨⑧⑦','sample')
列都是 nvarchar
数据类型。
当我运行此查询时:
select *
from URLs
where URL = '⑨⑧⑦'
找到插入的行,但特殊字符在 Management Studio 中显示为 ???
。
同一个表中还有其他行是通过数据库组件以编程方式插入的,其中 SSMS 中的 T-sql 查询会在这些相同字段中显示特殊字符;但是,当特殊字符位于 where 子句中时,sql 查询不会找到这些行。
解决方法
如果这些是“特殊”字符,并且列的数据类型是 nvarchar
- 那么您必须为您的字符串文字使用 N'...'
前缀以避免不必要的转换回非 Unicode 值。
使用这个
INSERT INTO URLs (URL,QuestionID)
VALUES (N'⑨⑧⑦',N'sample')
还有这个:
SELECT *
FROM URLs
WHERE URL = N'⑨⑧⑦'
确保您的字符在任何相关的地方都被视为 Unicode。