繁体   English   中英

使用C#在xml节点中添加属性

[英]Adding attribute in the node of xml using c#

<?xml version="1.0" encoding="UTF-8"?>
<definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL">
 <process id="sid-C3803939-0872-457F-8336-EAE484DC4A04" name="Customer" processType="None" isClosed="false" isExecutable="false">
    <userTask id="Task_1fxai2y" name="ut124" />
  </process>

我正在从数据库中检索此XML,现在我必须在“ userTask”标签中添加属性“ assignee = abc”并将其再次保存到数据库中,我正在尝试此代码,它没有给出任何错误,但是该属性没有添加。

  string a;
  SqlCommand cmd2 = new SqlCommand("select * from usertask1 where DIAGRAMID 
                        = " + idnum + "", con);

        con.Open();
        SqlDataReader rdr2 =  cmd2.ExecuteReader();
        if (rdr2.HasRows)
        {
            while (rdr2.Read())
            {

                string a = rdr2["XMLFILE"].ToString();// variable 'a' now has the xml

                XmlDocument xd = new XmlDocument();
                xd.LoadXml(a);
              XmlNodeList list = xd.GetElementsByTagName("userTask");
                  XmlAttribute XA = xd.CreateAttribute("ASSIGNEE");
                           XA.Value = "abc";
                           list[0].Attributes.Append(XA);
         }
}
//code to insert the xml again back to DB

您的代码看起来正确。 检查您的xml结构或也尝试这种方法

    XmlDocument xd = new XmlDocument();
    xd.LoadXml("<root>" +
            "<userTask></userTask>" +
            "<userTask></userTask>" +
        "</root>");
    XmlNodeList list = xd.GetElementsByTagName("userTask");
    XmlElement el = (XmlElement)list[0];
    el.SetAttribute("ASSIGNEE", "abc");

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM