gpt4 book ai didi

.net - 从 SQL Server 中的 XML 批量插入

转载 作者:数据小太阳 更新时间:2023-10-29 02:27:53 27 4
gpt4 key购买 nike

我正在尝试在 SQL Server 中使用 XML 插入数据。我使用的 XML 是

<ArrayOfInfringementEntity xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<InfringementEntity>
<infringementNumber>12345678911</infringementNumber>
<issueAgency>017</issueAgency>
<infringementType>1A</infringementType>
<infringementStatus>0</infringementStatus>
<batchRecordId>0</batchRecordId>
<incidentDate xsi:nil="true" />
<infringementSource>OTS</infringementSource>
<TypeOfNotice>0</TypeOfNotice>
<offenceEntity>
<offenceCode>7777</offenceCode>
<offenceDate>1999-05-31T00:00:00</offenceDate>
<offenceTime>121212</offenceTime>
<offenceLocation>ST56789</offenceLocation>
<offenceOwnerType>0</offenceOwnerType>
<offenceSuburb>SOUTH YARRA</offenceSuburb>
<site>ST56789</site>
<detectedSpeed>70</detectedSpeed>
<allegedSpeed>60</allegedSpeed>
<permittedSpeed>50</permittedSpeed>
<timeInRedLight>40</timeInRedLight>
<tollAmount>140</tollAmount>
<enforcementAllowance>310</enforcementAllowance>
<lookUpFee>510</lookUpFee>
<invoiceFee>130</invoiceFee>
</offenceEntity>
<vehicleEntity>
<vehicleClass>2</vehicleClass>
<vehicleMake>BMW</vehicleMake>
<vehicleModel>FOUR WHEELER</vehicleModel>
<bodyType>HEAVY</bodyType>
<primaryColour>GRN</primaryColour>
<manufactureYear>2010</manufactureYear>
<gvm>111</gvm>
<gcm>210</gcm>
<registrationNumber>CBD-1111</registrationNumber>
<registrationState>VIC</registrationState>
</vehicleEntity>
<obligationNumber>obligation1</obligationNumber>
<isDebtorDeceased>false</isDebtorDeceased>
</InfringementEntity>
</ArrayOfInfringementEntity>

我想在临时表中分解此 XML。我尝试使用

create table #InfTemp

(infringementNumber Varchar(10),issueAgency varchar(5),infringementType varchar(5), offenceCode int,vehicleClass int,obligationNumber varchar(11)
)

Insert into #InfTemp
SELECT PLIxml.infringementNumber, PLIxml.issueAgency,PLIxml.infringementType,
PLIxml.offenceCode , PLIxml.vehicleClass ,PLIxml.obligationNumber
FROM OPENXML (@output, 'ArrayOfInfringementEntity/InfringementEntity',2)
WITH
( infringementNumber Varchar(10),issueAgency varchar(5),infringementType varchar(5),offenceCode int,vehicleClass int,obligationNumber varchar(11)
) PLIxml

但我在 Offencecode 和车辆类别中得到 Null。据我了解,这是有道理的,因为 <offenceCode><offenceEntity> 的子节点。而且我并不是专门阅读 <offenceEntity> 节点。请帮忙。

最佳答案

根据您的 XML,您可以使用此 XQuery SELECT 从 XML 中提取您的项目:

select
@input.value('(/ArrayOfInfringementEntity/InfringementEntity/infringementNumber)[1]', 'VARCHAR(10)') 'InfringementNumber',
@input.value('(/ArrayOfInfringementEntity/InfringementEntity/issueAgency)[1]', 'VARCHAR(5)') 'Issue Agency',
@input.value('(/ArrayOfInfringementEntity/InfringementEntity/infringementType)[1]', 'VARCHAR(5)') 'Infringement Type',
@input.value('(/ArrayOfInfringementEntity/InfringementEntity/offenceEntity/offenceCode)[1]', 'INT') 'Offence Code',
@input.value('(/ArrayOfInfringementEntity/InfringementEntity/vehicleEntity/vehicleClass)[1]', 'INT') 'Vehicle Class',
@input.value('(/ArrayOfInfringementEntity/InfringementEntity/obligationNumber)[1]', 'VARCHAR(11)') 'Obligation Number'

@input 替换为包含 XML 的变量或列(我在测试中使用 @input 作为测试平台)。

输出看起来像这样:

InfringementNumber  Issue Agency    Infringement Type   Offence Code    Vehicle Class   Obligation Number
1234567891 017 1A 7777 2 obligation1

当然,您也可以执行 INSERT INTO .... 并将此 SELECT 的输出用作要插入的值。

更新:如果您的 XML 列包含多个条目(/ArrayOfInfringementEntity 中的 /InfringementEntity),您需要使用 SELECT 像这样:

SELECT
InfrEntity.value('(infringementNumber)[1]', 'VARCHAR(10)') 'InfringementNumber',
InfrEntity.value('(issueAgency)[1]', 'VARCHAR(5)') 'Issue Agency',
InfrEntity.value('(infringementType)[1]', 'VARCHAR(5)') 'Infringement Type',
InfrEntity.value('(offenceEntity/offenceCode)[1]', 'INT') 'Offence Code',
InfrEntity.value('(vehicleEntity/vehicleClass)[1]', 'INT') 'Vehicle Class',
InfrEntity.value('(obligationNumber)[1]', 'VARCHAR(11)') 'Obligation Number'
from
(yourXMLcolumn).nodes('/ArrayOfInfringementEntity/InfringementEntity') as ArrInfr(InfrEntity)

关于.net - 从 SQL Server 中的 XML 批量插入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4660398/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com