如何修复 Microsoft SQL Server Management Studio v18 中 UTF-8 数据显示不一致的问题并正确处理这些数据?

问题描述

我在连接到 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