微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

将单个 xml 节点作为数组转换为 json

如何解决将单个 xml 节点作为数组转换为 json

我的存储过程中有以下这样的代码。我正在使用 Newtonsoft 库将此 xml 转换为 json。部门可能有一个或多个值。我想在将此 xml 转换为 json 时强制将其作为数组。我该怎么做。如何在 sql 存储过程中将 json:Array='true' 添加到我的部门节点中。以及我需要在 C# 代码中进行哪些更改。

SELECT @xml = (
select p.fname,p.lname,(
   select dept.name,dept.address
   from department dept inner join tbloffice off on off.officeid = dept.officeid
   where off.officeid=p.officeid
   FOR XML PATH('dept_detail'),TYPE
)
from person p
WHERE p.id = @ID
FOR XML PATH('person'),ROOT('export_person'),TYPE
)
RETURN @xml

对于多条记录:

<export_person>
<person>
<fname>James</fname>
<lname>Williams</lname>
 <dept_details>
     <name>Engineering</name>
     <address>117,street</address>
  </dept_details>
  <dept_details>
     <name>Science</name>
     <address>119,street</address>
  </dept_details>
</person>
</export_person>

单条记录:

<export_person>
<person>
<fname>James</fname>
<lname>Williams</lname>
 <dept_details>
     <name>Engineering</name>
     <address>117,street</address>
  </dept_details>
</person>
</export_person>

多部门记录形成为

{
  "export_person": {
    "person": {
      "fname": "James","lname": "Williams","dept_details": [
        {
          "name": "Engineering","address": "117,street"
        },{
          "name": "Science","address": "119,street"
        }
      ]
    }
  }
}

我希望这个单一的部门记录也应该是这样的

{
  "export_person": {
    "person": {
      "fname": "James",street"
        }
      ]
    }
  }
}

目前它形成为

{
  "export_person": {
    "person": {
      "fname": "James","dept_details":
        {
          "name": "Engineering",street"
        }
    }
  }
}

目前我正在使用以下 C# 代码来形成 json。我正在从丢弃 export_person 包装器的 person 节点收集数据。

XmlDocument doc = new XmlDocument();
List<XElement> lstXelements = xmlExp.Elements().ToList();
List<dynamic> lstXelementJson = new List<dynamic>();

foreach (XElement Xele in lstXelements)
{
    string nodeName = lstXelements[0].Name.LocalName.ToString();
    doc.LoadXml(Xele.ToString());
    var jsonData = JObject.Parse(JsonConvert.SerializeXmlNode(doc))[nodeName];
    lstXelementJson.Add(jsonData);
}

解决方法

您是否尝试过直接从 SQL Server 生成 JSON?

declare @JSON nvarchar(max) = (
  select
    p.fname as 'export_person.person.fname',p.lname as 'export_person.person.lname',(
      select
        dept.name,dept.address
     from dbo.department dept
     inner join dbo.office [off] on [off].officeid = dept.officeid
     for json path
    ) as 'export_person.person.dept_details'
  from person p
  where p.id = @ID
  for json path,without_array_wrapper
);
select @JSON as someColumnName;

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

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?