如何修复 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。
我在连接到 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。