【发布时间】:2011-02-22 10:07:59
【问题描述】:
我有一些 xml 编码为 UTF-8,我想将其写入 SQL Server 中的文本字段。 UTF-8 与 Text 是字节兼容的,所以它应该能够做到这一点,然后读出 xml,以后仍然编码为 utf-8。
但是,在 UTF-8 中是多字节的特殊字符(例如 ÄÅÖ)会在途中发生变化。
我有这样的代码:
byte[] myXML = ...
SqlCommand _MyCommand = new SqlCommand(storeProcedureName, pmiDB.GetADOConnection());
_MyCommand.CommandType = CommandType.StoredProcedure;
_MyCommand.Parameters.Add("xmlText", SqlDbType.Text);
_MyCommand.Parameters["xmlText"].Value = Encoding.UTF8.GetString(myXML);
_MyCommand.ExecuteNonQuery();
我的猜测是,将 xml 字节数组更改为字符串会将特殊字符更改为 UTF-16 字符,然后再次更改为 Latin1。而且 Latin1 ÖÄÅ 与 UTF-8 ÖÄÅ 不同。
如何将 UTF-8 xml 字节写入文本字段而不改变它们?
【问题讨论】:
-
你遇到过这篇文章吗? support.microsoft.com/kb/232580
-
谢谢迈克,不幸的是,它似乎大多说不要将其存储为 UTF-8
标签: c# sql-server utf-8 sqlcommand