2017-03-29 14 views
1

XMLファイルをSQL Serverのテーブルにインポートしようとしています。私はテーブルにnull値を得ることになったXMLデータをテーブルにインポートするときにNULL値を取得する

Declare @x xml 

Select @x = p 
      from OpenRowSet(BULK 'C:\Users\sivat\OneDrive\Projects\SQL Server  Projects\Books.xml',SINGLE_BLOB) as BOOKS(p) 

Declare @hdoc int 

exec sp_xml_preparedocument @hdoc output,@x 

IF OBJECT_ID('BOOKS') IS NOT NULL 
    DROP Table BOOKS 

select * 
into BOOKS 
from openxml(@hdoc,'/catalog/book',2) 
with 
( Author nvarchar(150), 
    Title nvarchar(150), 
    Genre nvarchar(150), 
    Price float, 
    Publish_Date Date, 
    Description nvarchar(200)) 
exec sp_xml_removedocument @hdoc 
select * from BOOKS 

を私は何をする必要があります

何を修正..:ここ

は、私が書いたコードはありますか?ここで

は、元のXMLファイルです:ビルトインのXQuery方法ではなく不格好、メモリリークするOPENXMLものよりも、私はネイティブを使用することを好むだろう

<?xml version="1.0"?> 
<catalog> 
    <book id="bk101"> 
     <author>Gambardella, Matthew</author> 
     <title>XML Developer's Guide</title> 
     <genre>Computer</genre> 
     <price>44.95</price> 
     <publish_date>2000-10-01</publish_date> 
     <description>An in-depth look at creating applications 
     with XML.</description> 
    </book> 
    <book id="bk102"> 
     <author>Ralls, Kim</author> 
     <title>Midnight Rain</title> 
     <genre>Fantasy</genre> 
     <price>5.95</price> 
     <publish_date>2000-12-16</publish_date> 
     <description>A former architect battles corporate zombies, 
     an evil sorceress, and her own childhood to become queen 
     of the world.</description> 
    </book> 
    <book id="bk103"> 
     <author>Corets, Eva</author> 
     <title>Maeve Ascendant</title> 
     <genre>Fantasy</genre> 
     <price>5.95</price> 
     <publish_date>2000-11-17</publish_date> 
     <description>After the collapse of a nanotechnology 
     society in England, the young survivors lay the 
     foundation for a new society.</description> 
    </book> 
    <book id="bk104"> 
     <author>Corets, Eva</author> 
     <title>Oberon's Legacy</title> 
     <genre>Fantasy</genre> 
     <price>5.95</price> 
     <publish_date>2001-03-10</publish_date> 
     <description>In post-apocalypse England, the mysterious 
     agent known only as Oberon helps to create a new life 
     for the inhabitants of London. Sequel to Maeve 
     Ascendant.</description> 
    </book> 
    <book id="bk105"> 
     <author>Corets, Eva</author> 
     <title>The Sundered Grail</title> 
     <genre>Fantasy</genre> 
     <price>5.95</price> 
     <publish_date>2001-09-10</publish_date> 
     <description>The two daughters of Maeve, half-sisters, 
     battle one another for control of England. Sequel to 
     Oberon's Legacy.</description> 
    </book> 
    <book id="bk106"> 
     <author>Randall, Cynthia</author> 
     <title>Lover Birds</title> 
     <genre>Romance</genre> 
     <price>4.95</price> 
     <publish_date>2000-09-02</publish_date> 
     <description>When Carla meets Paul at an ornithology 
     conference, tempers fly as feathers get ruffled.</description> 
    </book> 
    <book id="bk107"> 
     <author>Thurman, Paula</author> 
     <title>Splish Splash</title> 
     <genre>Romance</genre> 
     <price>4.95</price> 
     <publish_date>2000-11-02</publish_date> 
     <description>A deep sea diver finds true love twenty 
     thousand leagues beneath the sea.</description> 
    </book> 
    <book id="bk108"> 
     <author>Knorr, Stefan</author> 
     <title>Creepy Crawlies</title> 
     <genre>Horror</genre> 
     <price>4.95</price> 
     <publish_date>2000-12-06</publish_date> 
     <description>An anthology of horror stories about roaches, 
     centipedes, scorpions and other insects.</description> 
    </book> 
    <book id="bk109"> 
     <author>Kress, Peter</author> 
     <title>Paradox Lost</title> 
     <genre>Science Fiction</genre> 
     <price>6.95</price> 
     <publish_date>2000-11-02</publish_date> 
     <description>After an inadvertant trip through a Heisenberg 
     Uncertainty Device, James Salway discovers the problems 
     of being quantum.</description> 
    </book> 
    <book id="bk110"> 
     <author>O'Brien, Tim</author> 
     <title>Microsoft .NET: The Programming Bible</title> 
     <genre>Computer</genre> 
     <price>36.95</price> 
     <publish_date>2000-12-09</publish_date> 
     <description>Microsoft's .NET initiative is explored in 
     detail in this deep programmer's reference.</description> 
    </book> 
    <book id="bk111"> 
     <author>O'Brien, Tim</author> 
     <title>MSXML3: A Comprehensive Guide</title> 
     <genre>Computer</genre> 
     <price>36.95</price> 
     <publish_date>2000-12-01</publish_date> 
     <description>The Microsoft MSXML3 parser is covered in 
     detail, with attention to XML DOM interfaces, XSLT processing, 
     SAX and more.</description> 
    </book> 
    <book id="bk112"> 
     <author>Galos, Mike</author> 
     <title>Visual Studio 7: A Comprehensive Guide</title> 
     <genre>Computer</genre> 
     <price>49.95</price> 
     <publish_date>2001-04-16</publish_date> 
     <description>Microsoft Visual Studio 7 is explored in depth, 
     looking at how Visual Basic, Visual C++, C#, and ASP+ are 
     integrated into a comprehensive development 
     environment.</description> 
    </book> 
</catalog> 

答えて

1

.....

この唯一ディスプレイ値、もちろん

DECLARE @x XML 

SELECT @x = p FROM OpenRowSet(BULK 'C:\Users\sivat\OneDrive\Projects\SQL Server Projects\Books.xml',SINGLE_BLOB) as BOOKS(p) 

SELECT 
    Author = xc.value('(author)[1]', 'nvarchar(150)'), 
    Title = xc.value('(title)[1]', 'nvarchar(150)'), 
    Genre = xc.value('(genre)[1]', 'nvarchar(150)'), 
    Price = xc.value('(price)[1]', 'decimal(15,2)'), 
    Publish_Date = xc.value('(publish_date)[1]', 'date'), 
    Description = xc.value('(genre)[1]', 'nvarchar(200)') 
FROM 
    @x.nodes('/catalog/book') AS XT(XC) 

- しかし、あなたは簡単に、最終的に置き換えることができます。このコードを試してみてください

INSERT INTO dbo.Books(Author, Title, Genre, Price, Publish_Date, Description) 
    SELECT 
     Author = xc.value('(author)[1]', 'nvarchar(150)'), 
     Title = xc.value('(title)[1]', 'nvarchar(150)'), 
     Genre = xc.value('(genre)[1]', 'nvarchar(150)'), 
     Price = xc.value('(price)[1]', 'decimal(15,2)'), 
     Publish_Date = xc.value('(publish_date)[1]', 'date'), 
     Description = xc.value('(genre)[1]', 'nvarchar(200)') 
    FROM 
     @x.nodes('/catalog/book') AS XT(XC) 

と(この文を実行する前に存在している必要があり)表dbo.Booksにデータを挿入します。これでSELECT

も注意してください。私は(丸め誤差に悪名高い感受性がある)floatからPriceのためのデータ型を変更し、あなたが+1 :-)秒で私を倒す

+0

(これらの丸め誤差のどれを持っていない)の代わりにdecimal(15,2)を選びました私の側から – Shnugo

+1

私はテーブルに値を持っています非常に@ marc_s –

+0

@ Shnugo:私のミドルネームは何のための "スピーディーフィンガーズ"ではありません:D –

関連する問題