gpt4 book ai didi

sql - T-SQL : cross apply; too many iterations on line items

转载 作者:行者123 更新时间:2023-12-04 05:29:06 24 4
gpt4 key购买 nike

在粉碎了一些严肃的 Xml 之后,我几乎得到了我想要的东西——但是在查看结果之后,我看到在解析的一个部分中,我无法轻松解决这种遍历所有行细节的模式每个子标题——所以不是为所有行项目写出总共 3 条记录,而是为每个子项目写出三个行项目——假设我有两个。我一共得到了 6 个! :-( 我在下面的代码中将模式提炼为通用标题/子标题/细节关系模型。

    DECLARE @MetroXML xml
SET @MetroXML =
'<Header>
<col1>Conoco</col1>
<col2>ORD-1111</col2>
<SubHeaders>
<SubHeader>
<col1>Dallas</col1>
<col2>BOL-2213</col2>
<Details>
<Detail>
<col1>Diesel</col1>
<col2>7600.00</col2>
</Detail>
</Details>
</SubHeader>
</SubHeaders>
<SubHeaders>
<SubHeader>
<col1>Fort Worth</col1>
<col2>BOL-2216</col2>
<Details>
<Detail>
<col1>Ethanol</col1>
<col2>1852.00</col2>
</Detail>
<Detail>
<col1>Unleaded</col1>
<col2>900.00</col2>
</Detail>
</Details>
</SubHeader>
</SubHeaders>
</Header>';


INSERT INTO [scratch].GenericHeader
SELECT T.c.value('col1[1]','varchar(10)') AS 'col1',
T.c.value('col2[1]','varchar(10)') AS 'col2'
FROM @MetroXML.nodes('/Header') T(c);


INSERT [scratch].GenericSubHeader
(id,col1,col2)
SELECT
h.id,
n.x.value('col1[1]','varchar(10)') AS 'col1',
n.x.value('col2[1]','varchar(10)') AS 'col2'
FROM [scratch].GenericHeader h
CROSS APPLY @MetroXML.nodes('/Header/SubHeaders/SubHeader') n(x);


INSERT [scratch].GenericDetail
(id,subid,col1,col2)
SELECT
s.id,
s.subid,
n.x.value('col1[1]','varchar(10)') AS 'col1',
n.x.value('col2[1]','varchar(10)') AS 'col2'
FROM [scratch].GenericSubHeader s
CROSS APPLY @MetroXML.nodes('/Header/SubHeaders/SubHeader/Details/Detail') as n(x);


select * from [scratch].GenericHeader
where id = 24;

select * from [scratch].GenericSubHeader
where id = 24;

select * from [scratch].GenericDetail
where id = 24;

注意:id、subid、detid 定义为 INT IDENTITY(1,1)
结果

我得到的:
id|subid|detid|col1     |col2
--------------------------------
24|44 |22 |Diesel |7600.00
24|44 |23 |Ethanol |1852.00
24|44 |24 |Unleaded |900.00
24|48 |25 |Diesel |7600.00
24|48 |26 |Ethanol |1852.00
24|48 |27 |Unleaded |900.00

我想得到什么:
id|subid|detid|col1     |col2
--------------------------------
24|44 |22 |Diesel |7600.00
24|48 |23 |Ethanol |1852.00
24|48 |24 |Unleaded |900.00

最佳答案

你得到重复行的原因是你对 GenericSubHeader 中每一行的整个 XML 使用交叉应用。 .你必须想办法映射生成的IDGenericHeader和生成的 subidGenericSubHeader到 XML 的相关部分。

如果您使用的是 SQL Server 2008 或更高版本,则可以 merge with output创建一个表变量,其中包含生成的 id 和所属的 xml 子节点。

declare @GH table
(
id int,
sub xml
);

merge scratch.GenericHeader as T
using
(
select T.c.value('col1[1]','varchar(10)'),
T.c.value('col2[1]','varchar(10)'),
T.c.query('SubHeaders')
from @MetroXML.nodes('/Header') T(c)
) as S(col1, col2, sub)
on 0 = 1
when not matched then
insert (col1, col2) values(S.col1, S.col2)
output inserted.id, S.sub into @GH;

declare @GSH table
(
id int,
subid int,
det xml
);

merge scratch.GenericSubHeader as T
using
(
select h.id,
n.x.value('col1[1]','varchar(10)'),
n.x.value('col2[1]','varchar(10)'),
n.x.query('Details')
from @GH as h
cross apply h.sub.nodes('/SubHeaders/SubHeader') n(x)
) as S(id, col1, col2, det)
on 0 = 1
when not matched then
insert (id, col1, col2) values (S.id, S.col1, S.col2)
output inserted.id, inserted.subid, S.det into @GSH;

insert into scratch.GenericDetail(id, subid, col1, col2)
select s.id,
s.subid,
n.x.value('col1[1]','varchar(10)') AS 'col1',
n.x.value('col2[1]','varchar(10)') AS 'col2'
from @GSH as s
cross apply s.det.nodes('/Details/Detail') as n(x);

关于sql - T-SQL : cross apply; too many iterations on line items,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12849790/

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