如何解决如何修复 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。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。