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

How can I fix inconsistent display of UTF-8 data in Microsoft SQL Server Management Studio v18 and properly handle this data?

我在连接到 SQL Server 2019 数据库的 Microsoft SQL Server Management Studio 18 中输入了这个查询:

insert into URLs (URL, QuestionID) 
values ('⑨⑧⑦', 'sample')

这些列都是 nvarchar 数据类型。

当我运行这个查询时:

select * 
from URLs 
where URL = '⑨⑧⑦'

找到插入的行,但特殊字符在 Management Studio 中显示为 ???

同一个 table 中还有其他行是通过数据库组件以编程方式插入的,其中 SSMS 中的 T-SQL 查询显示这些相同字段中的特殊字符;但是,当特殊字符位于 where 子句中时,SQL 查询不会找到这些行。

如果这些是“特殊”字符,并且列的数据类型是 nvarchar - 那么您 必须 使用 N'...' 前缀作为字符串文字避免不必要的转换回非 Unicode 值。

使用这个

INSERT INTO URLs (URL, QuestionID) 
VALUES (N'⑨⑧⑦', N'sample')

还有这个:

SELECT * 
FROM URLs 
WHERE URL = N'⑨⑧⑦'

以确保您的字符在所有相关的地方都被真正视为 Unicode