我将大量XML参数从我的应用程序传递到SQL Server(Windows和ASP.Net应用程序)
之前我曾经使用字符串中的基于串联的运算符来构建XML,类似于下面的那个。
string XmlDetails = string.Empty;
XmlDetails = "<APPLICATION><SEND>";
XmlDetails += "<ID>" + txtCardNo.Text.ToString() + "</ID>";
XmlDetails += "</SEND></APPLICATION>";
该应用程序真的用于占用内存并且非常慢。我将连接方法更改为String Builder类以构建大型XML。
XmlDetails = string.Format("{0}<{1}>{2}</{1}>", "<APPLICATION><SEND>", "ID", txtCardNo.Text.ToString());
XmlDetails = string.Format("{0}<{1}>{2}</{1}>{3}", XmlDetails, "PAYDET", txtPOSPaydet.Text.ToString(), "</SEND></APPLICATION>");
使用上述方法时,我的应用程序使用的内存级别发生了巨大变化。
我想知道在我的申请中是否有更好的方法可以使用。
答案 0 :(得分:1)
您可以选择几种方式:
XElement,它允许您手动编写XML而无需自己构建字符串,但是就像这样:
XElement xmlTree1 = new XElement("Root",
new XElement("Child1", 1),
new XElement("Child2", 2),
new XElement("Child3", 3)
);
Console.WriteLine(xmlTree2);
这将写入控制台:
<Root>
<Child1>1</Child1>
<Child2>2</Child2>
<Child3>3</Child3>
</Root>
如果您的XML格式是静态的,您还可以创建一个表示数据的对象,将其标记为[Serializable]
,然后将其序列化:
public static void Main(string[] args)
{
var myObjectToSerialize = new Root()
{
Child1 = 1,
Child2 = 2,
Child3 = 3
};
var serializer = new XmlSerializer(typeof(Root));
serializer.Serialize(Console.Out, myObjectToSerialize);
Console.ReadKey();
}
使用以下课程:
[Serializable]
public class Root
{
public int Child1 { get; set; }
public int Child2 { get; set; }
public int Child3 { get; set; }
}
答案 1 :(得分:0)
为什么不使用XDocument类。
var doc = new XDocument(
new XElement("APPLICATION",
new XElement("SEND",
new XElement("ID", txtCardNo.Text.ToString())
)
)
);