html - sql中如何获取奇数节点和偶数节点的值

标签 html sql sql-server

本例SQL如何获取奇偶节点的值?

declare @htmlXML xml = N'<div class="screen_specs_container  "><div class="left_specs_container">Compatibility:</div><div class="right_specs_container "><h4>Acer ASPIRE 1200</h4></div><div class="left_specs_container" data-filterlabel="Replacement Part Type:">Replacement Part Type</div><div class="right_specs_container spec_highlight"> LCD Screen Only<a class="thickbox" title="" href="/laptopscreen_viewer.php?edit_language=English&amp;view_article=1468010881&amp;height=500&amp;width=800"><img valign="middle" alt="?" src="/images/question2.gif" border="0"></img></a></div><div class="left_specs_container" data-filterlabel="Size:">Size:</div><div class="right_specs_container" title="size">14.1-inch Screen (11.3"x8.4")<a class="lightbox" title="" href="//www.youtube.com/embed/_zalTiJ1vFY?autoplay=1"><img valign="middle" alt="?" src="/images/question2.gif" border="0"></img></a></div><div class="left_specs_container" data-filterlabel="Resolution:">Resolution:</div><div class="right_specs_container" title="resolution">XGA (1024x768)<a class="lightbox" title="" href="//www.youtube.com/embed/WWPSXibVLkg?autoplay=1"><img valign="middle" alt="?" src="/images/question2.gif" border="0"></img></a></div><div class="left_specs_container" data-filterlabel="Surface Type:">Surface Type:</div><div class="right_specs_container" title="type"><font color="red">Matte<a class="lightbox" title="" href="//www.youtube.com/embed/gt_CSbMF-5o?autoplay=1"><img valign="middle" alt="?" src="/images/question2.gif" border="0"></img></a></font></div><div class="left_specs_container" style="display:none" data-filterlabel="Touchscreen Panel:">Touchscreen Panel:</div><div class="right_specs_container" style="display:none">Not Included</div><div class="left_specs_container" data-filterlabel="Backlight type:">Backlight type:</div><div class="right_specs_container" title="backlight-type">CCFL 1-Bulb<a class="lightbox" title="" href="//www.youtube.com/embed/4F0xPuz4Jnw?autoplay=1"><img valign="middle" alt="?" src="/images/question2.gif" border="0"></img></a></div><div class="left_specs_container">Video signal connector:</div><div class="right_specs_container">30 pin CCFL screen[<a target="blank" class="thickbox laptops" title="Video Connector" href="/img/connectors/1_big/30pinsCCFL.jpg">image</a>]</div><div class="left_specs_container">Condition:</div><div class="right_specs_container">New Grade A+<a class="thickbox" title="" href="/laptopscreen_viewer.php?edit_language=English&amp;view_article=1243967715&amp;height=500&amp;width=800"><img valign="middle" alt="?" src="/images/question2.gif" border="0"></img></a></div><div class="left_specs_container">Warranty:</div><div class="right_specs_container">3 Years</div><div class="left_specs_container" style="color:#f00">Note:</div><div class="right_specs_container">Make sure new screen has same size, resolution, backlight as your old one!</div></div>'

SQL 代码:

SELECT  
    t.v.value('.','nvarchar(max)') as [TitleOfSpec],
    t.v.value('.','nvarchar(max)') as [valueOfSpec]
FROM
    @htmlXML.nodes('/div/div') AS p(parent)

输出

TitleOfSpec             ValueOfSpec
 (odd nodes)              (even nodes)
------------           ---------------
Compatibility:         Acer ASPIRE 1200
Replacement Part Type   LCD Screen Only
.....                       ......

谢谢 friend 们的指教

最佳答案

该方法首先展开div。
并使用 row_number 获得排名,将偶数节点与不均匀节点连接起来。

WITH Divs AS 
(
    SELECT 
    row_number() over (order by (select 0)) as rn,
    x.div.value('.','nvarchar(max)') as val
    from @htmlXML.nodes('/div/div') x(div) 
)
select
divs1.val as TitleOfSpec,
divs2.val as ValueOfSpec
from Divs divs1
left join Divs divs2
  on (divs1.rn+1 = divs2.rn)
where divs1.rn%2>0;

关于html - sql中如何获取奇数节点和偶数节点的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39941211/

相关文章:

javascript - 警告 javascript 生成的 div id

php - Laravel - 从一个表中获取另一个表中不存在的记录并附加 where 子句

c# - 如何解决销售数据库中的并发事务问题

c# - 在Amazon Web Services上扩展SQL Server

javascript - 照片网格就像新的 flickr 设计

javascript - 在 Javascript 中创建和更改 HTML 元素

javascript - jQuery Mobile : alternative of . 触发 ('create' ) 或 .page() 更新导航栏时?

sql - 简单的 MS SQL 计数问题

sql - 如何在 SQL 查询中使用 LIKE 转义

sql - 逐行复制表格