我有一个这样的表:
create table product
(
id integer,
category varchar(50),
quantity integer,
techdata varchar(100),
cost_price float
);
insert into product
values (1, 'window', 2, '<Data w="1000" h="1000"/>', 100.56),
(2, 'door', 1, '<Data w="900" h="1800"/>', 96.12),
(3, 'window', 20, '<Data w="750" h="300"/>', 152.5),
(4, 'door', 100, '<Data w="1046" h="2046"/>', 46.74),
(5, 'window', 1, null, null);
我必须从这些行中选择所有的“ w”和“ h”属性值。我已经尝试过此解决方案,但是它不起作用。
SELECT
t.p.value('(@w)[1]', 'VARCHAR(50)') AS width,
t.p.value('(@h)[1]', 'VARCHAR(50)') AS height
FROM
product
CROSS APPLY
techdata.nodes('/Data') t(p)
任何适当解决方案的提示?
我认为您的问题是,techdata列不是XML类型。
尝试这个
select
CONVERT(xml, techdata).value('(/Data/@w)[1]', 'int') as Width,
CONVERT(xml, techdata).value('(/Data/@h)[1]', 'int') as Height
from product
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句