Перенос таблицы в XML-поле Sql - PullRequest
2 голосов
/ 14 февраля 2012

Мне очень жаль за этот длинный вопрос!Я не знаю, как подвести итог.Случай очень прост, но я новичок в SQL XML.

У меня есть таблица, и я хочу перенести все ее записи в другую таблицу с одним столбцом xml.

Вотмоя таблица полей :

CREATE TABLE [dbo].[Fields] (
[Id]          BIGINT     IDENTITY (1, 1) NOT NULL,
[Title]       NCHAR (10) NOT NULL,
[Duration]    INT        NOT NULL,
[Cost]        MONEY      NOT NULL,
[Consignee]   BIGINT     NOT NULL,
[Date]        DATETIME   NOT NULL,
[TariffId]    BIGINT     NOT NULL,
[InvoiceType] NCHAR (10) NOT NULL,
[IsPayed]     BIT        NOT NULL
);

, а это моя таблица TypedXML :

CREATE TABLE [dbo].[TypedXml](
    [Id] [bigint] IDENTITY(1,1) NOT NULL,
    [InvoiceItem] [xml](CONTENT [dbo].[invoiceCollection])

с одной схемой коллекция вроде этого:

CREATE XML SCHEMA COLLECTION invoiceCollection AS 
'<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema" 
  xmlns="http://www.oliol.com" 
   elementFormDefault="qualified"
  targetNamespace="http://www.oliol.com">
 <xsd:element name="Invoice" type="InvoiceType" />
  <xsd:complexType name="InvoiceType">
    <xsd:sequence>
      <xsd:element name="Id" type="xsd:long" />
      <xsd:element name="Title" type="xsd:string" />
      <xsd:element name="Duration" type="xsd:long" />
      <xsd:element name="Cost" type="xsd:decimal" />
      <xsd:element name="Consignee" type="xsd:long" />
      <xsd:element name="Date" type="xsd:dateTime" />
      <xsd:element name="TariffId" type="xsd:long" />
      <xsd:element name="InvoiceType" type="xsd:string" />
      <xsd:element name="IsPayed" type="xsd:int" />
    </xsd:sequence>
  </xsd:complexType>
</xsd:schema>'

Теперь я пишу это в migrate :

declare @i bigint
set @i=1
while(@i<=10000)
begin

insert into dbo.TypedXML(invoiceitem)
values(
(SELECT  *
FROM Fields
where id=1
FOR XML PATH('Invoice')))
set @i=@i+1
End

Не может вставить, потому что он пытается вставить что-то вродеэто:

Вставить не удалось

<Invoice>
  <Id>1</Id>
  <Title>t1</Title>
  <Duration>726643700</Duration>
  <Cost>312118909727165.6133</Cost>
  <Consignee>3120910928797722624</Consignee>
  <Date>4543-07-16T01:40:29.623</Date>
  <TariffId>3120910928797722624</TariffId>
  <InvoiceType>it1</InvoiceType>
  <IsPayed>1</IsPayed>
</Invoice>

Хотя я могу вставить в TypedXML следующим образом:

Вставить Успешно

INSERT typedxml VALUES('
<xml version=1>
<Invoice xmlns="http://www.oliol.com">
  <Id>1</Id>
  <Title>t1</Title>
  <Duration>726643700</Duration>
  <Cost>312118909727165.6133</Cost>
  <Consignee>3120910928797722624</Consignee>
  <Date>4543-07-16T01:40:29.623</Date>
  <TariffId>3120910928797722624</TariffId>
  <InvoiceType>it1</InvoiceType>
  <IsPayed>1</IsPayed>
</Invoice>
')

Я хотел бы знать, как я могу изменить свой запрос на миграцию, чтобы добавить элемент xmlns = "http://www.oliol.com" к Invoice ?

ps: Я изменил это так: WITH XMLNAMESPACES ('http://www.oliol.com' as ns) SELECT * FROM Поля, где id = 1 FOR XML PATH (' Invoice '), но это не соответствует схеме, потому что она производит:

<Invoice xmlns:ns="http://www.shaar.com">
  <Id>1</Id>
  <Title>t1</Title>
  <Duration>726643700</Duration>
  <Cost>312118909727165.6133</Cost>
  <Consignee>3120910928797722624</Consignee>
  <Date>4543-07-16T01:40:29.623</Date>
  <TariffId>3120910928797722624</TariffId>
  <InvoiceType>it1</InvoiceType>
  <IsPayed>1</IsPayed>
</Invoice>

1 Ответ

1 голос
/ 15 февраля 2012

Укажите ваше пространство имен, используя default:

;WITH XMLNAMESPACES (default 'http://www.oliol.com')
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...