Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: XML в SQLserver 2000  (Прочитано 9782 раз)
0 Пользователей и 1 Гость смотрят эту тему.
PSD
Главный специалист

ru
Offline Offline
Пол: Мужской

« : 03-08-2004 06:06 » 

Суть проблемы, хочу использовать описание анных средствами XML для обмена данными между сервеом и приложениями.
Извлеч данные из сервера и впихнуть их в любое офисное приложение не проблема , а вот отработать эту цепочку в обратном порядке получатся не очень.

Ктонибудь может помоч с примерами как использовать XML для предачи данных из базы данных и обратно?

В качестве клиента Exel.
Записан

Да да нет нет все остальное от лукавого.
Dimka
Деятель
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #1 : 03-08-2004 12:59 » 

почитай в BOL про OPENXML. Сам не использовал, поэтому сказать не могу...
пример кода
Код:
DECLARE @idoc int
DECLARE @doc varchar(1000)
SET @doc ='
<ROOT>
<Customer CustomerID="VINET" ContactName="Paul Henriot">
   <Order CustomerID="VINET" EmployeeID="5" OrderDate="1996-07-04T00:00:00">
      <OrderDetail OrderID="10248" ProductID="11" Quantity="12"/>
      <OrderDetail OrderID="10248" ProductID="42" Quantity="10"/>
   </Order>
</Customer>
<Customer CustomerID="LILAS" ContactName="Carlos Gonzlez">
   <Order CustomerID="LILAS" EmployeeID="3" OrderDate="1996-08-16T00:00:00">
      <OrderDetail OrderID="10283" ProductID="72" Quantity="3"/>
   </Order>
</Customer>
</ROOT>'
--Create an internal representation of the XML document.
EXEC sp_xml_preparedocument @idoc OUTPUT, @doc
-- Execute a SELECT statement that uses the OPENXML rowset provider.
SELECT    *
FROM       OPENXML (@idoc, '/ROOT/Customer',1)
            WITH (CustomerID  varchar(10),
                  ContactName varchar(20))

Разумеется, XML должен быть представлен в определённой SQL Server схеме.
« Последнее редактирование: 30-11-2007 21:44 от Алексей1153++ » Записан

Программировать - значит понимать (К. Нюгард)
Невывернутое лучше, чем вправленное (М. Аврелий)
Многие готовы скорее умереть, чем подумать (Б. Рассел)
Oldy
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #2 : 03-08-2004 18:56 » 

PSD, а если через ADO? Кажется там есть интересующая вас возможность использования ХМL.
Записан

С уважением, Oldy.
PSD
Главный специалист

ru
Offline Offline
Пол: Мужской

« Ответ #3 : 04-08-2004 04:08 » 

Я прочитал доки, нашел и openxml и FOR XML у меня какойто дикий тупизм и я ни как не могу сообразить как мне это использовать для предачи данных из базы и для вставки  данных в базу, поэтому спрашиваю нет ли у кого готовых решений чтоб можно былопосмотреть как это юзается и где выгода.
Записан

Да да нет нет все остальное от лукавого.
Dimka
Деятель
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #4 : 04-08-2004 05:05 » 

PSD, теперь не понял...

Мне показалось, что тебя интересует как вставить/изменить/удалить данные в базе с одной стороны и запросить их с другой, так чтобы ввод/вывод осуществлялся через XML...

Раз можно написать 1) select, который читает данные из openxml - можно вводить данные из XML потоков, 2) select, который пишет данные в xml (for xml) - можно выводить данные в XML потоки. Операции вставки/изменения/удаления можно либо навесить на select, либо придётся писать хранимую процедуру, что нежелательно, так как максимальный буфер под поток (в виде строковй переменной) будет 8 Кб, что в иных случаях недостаточно. Основная задача клиента - преобразования в/из схему(ы) XML (DTD) SQL Server в свою внутреннюю. Решается либо написанием XSL преобразования, либо вручную (самостоятельно ходить по DOM и выуживать нужные данные).

Если же вопрос встал, как получить данные по сети в openxml... До работы дойду - погляжу Улыбаюсь
Записан

Программировать - значит понимать (К. Нюгард)
Невывернутое лучше, чем вправленное (М. Аврелий)
Многие готовы скорее умереть, чем подумать (Б. Рассел)
Dimka
Деятель
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #5 : 04-08-2004 07:25 » 

ну вот, в том же BOL читаем пример, о котором ты спрашивал:

на стороне сервера хранимая процедура
Код:
CREATE PROCEDURE SP_OpenXML_Example
      @XMLDoc varchar(2000)
AS
      DECLARE @ReturnCode INT
   DECLARE @iDoc int

      EXECUTE sp_xml_preparedocument @iDoc OUTPUT, @XMLDoc

   SELECT * FROM OpenXML(@iDoc, '/ROOT/Customers',1)
         WITH (CustomerID varchar(10), ContactName varchar(20))

   EXECUTE sp_xml_removedocument @iDoc

      SELECT @ReturnCode = 1
   RETURN @ReturnCode
GO
Здесь мы передаём в процедуру XML (не более 2000 байт длиной) и делаем по нему запрос. Результатом работы процедуры будет таблица с запрошенными данными.

На стороне клиента (для SQL сервера) ASP-страница на VB, использующая ADO:
Код:
<HTML>
<HEAD>
<META NAME="GENERATOR" Content="Microsoft Developer Studio"/>
<META HTTP-EQUIV="Content-Type" content="text/html" charset="iso-8859-1"/>
<TITLE>ADO 2.6 OpenXML Example - OpenXML.asp</TITLE>

<STYLE>
   BODY
   {
      FONT-FAMILY: Tahoma;
      FONT-SIZE: 8pt;
      OVERFLOW: auto
   }

   H3
   {
      FONT-FAMILY: Tahoma;
      FONT-SIZE: 8pt;
      OVERFLOW: auto
   }

</STYLE>

<!-- #include file="adovbs.inc" -->
<%
Response.Write "Page Generated @ " & Now() & "<BR/>"

   Dim sConn
   sConn = "Provider=SQLOLEDB;Data Source=MYSERVER1;Initial Catalog=Northwind;Trusted_Connection=yes;}

   Response.write "Connect String = " & sConn & "<BR/>"

   Dim adoConn
   Set adoConn = Server.CreateObject("ADODB.Connection")
   adoConn.ConnectionString = sConn
   adoConn.CursorLocation = adUseClient
   adoConn.Open

   Response.write "ADO Version = " & adoConn.Version & "<BR/>"
   Response.write "adoConn.State = " & adoConn.State & "<BR/>"

   Dim sXMLDoc, sQuery

   sXMLDoc = "<ROOT>"
   sXMLDoc = sXMLDoc & "<Customers CustomerID='VINET' ContactName='Paul Henriot'>"
   sXMLDoc = sXMLDoc & "<Orders CustomerID='VINET' EmployeeID='5' OrderDate='1996-07-04T00:00:00'>"
   sXMLDoc = sXMLDoc & "<Order_0020_Details OrderID='10248' ProductID='11' Quantity='12'/>"
   sXMLDoc = sXMLDoc & "<Order_0020_Details OrderID='10248' ProductID='42' Quantity='10'/>"
   sXMLDoc = sXMLDoc & "</Orders>"
   sXMLDoc = sXMLDoc & "</Customers>"
   sXMLDoc = sXMLDoc & "<Customers CustomerID='LILAS' ContactName='Carlos Gonzlez'>"
   sXMLDoc = sXMLDoc & "<Orders CustomerID='LILAS' EmployeeID='3' OrderDate='1996-08-16T00:00:00'>"
   sXMLDoc = sXMLDoc & "<Order_0020_Details OrderID='10283' ProductID='72' Quantity='3'/>"
   sXMLDoc = sXMLDoc & "</Orders>"
   sXMLDoc = sXMLDoc & "</Customers>"
   sXMLDoc = sXMLDoc & "</ROOT>"

sQuery = "SP_OpenXML_Example"
   Response.write "sQuery = " & sQuery & "<BR/>"

   Dim adoCmd
   Set adoCmd = Server.CreateObject("ADODB.Command")
   Set adoCmd.ActiveConnection = adoConn
   adoCmd.CommandText = sQuery
   adoCmd.CommandType = adCmdStoredProc
   adoCmd.Parameters.Refresh
   adoCmd.Parameters.Item(1).Value = sXMLDoc

   Dim adoRS
   Set adoRS = adoCmd.Execute()

   Response.write "Data = " & adoRS.Fields(0).Value & "<BR/>"
   adoRS.Close

   Response.write "ReturnValue = " & adoCmd.Parameters.Item(0).Value & "<BR/>"

%>
</HEAD>
<BODY>
</BODY>
</HTML>
Здесь мы вручную составляем строчку XML, а затем средствами ADO вызваем описанную выше хранимую процедуру, куда в качестве параметра передаём строчку XML-документа. Далее я не так хорошо знаю VB, чтобы сказать, что делается потом. Подозреваю, что выводится значение первой колонки первой (вот этого я и не вижу - может опечатка) строки полученной таблицы, а также код возврата процедуры (в данном случае 1).
« Последнее редактирование: 30-11-2007 21:45 от Алексей1153++ » Записан

Программировать - значит понимать (К. Нюгард)
Невывернутое лучше, чем вправленное (М. Аврелий)
Многие готовы скорее умереть, чем подумать (Б. Рассел)
Dimka
Деятель
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #6 : 04-08-2004 07:33 » 

вот пример вставки в таблицу из OPENXML (из того же BOL)
Код:
DECLARE @hDoc int
EXEC sp_xml_preparedocument @hDoc OUTPUT,
      N'<ROOT>
         <Customers CustomerID="XYZAA" ContactName="Joe"
               CompanyName="Company1">
            <Orders CustomerID="XYZAA"
               OrderDate="2000-08-25T00:00:00"/>
            <Orders CustomerID="XYZAA"
               OrderDate="2000-10-03T00:00:00"/>
         </Customers>
         <Customers CustomerID="XYZBB" ContactName="Steve"
               CompanyName="Company2">No Orders yet!
         </Customers>
      </ROOT>'
-- Use OPENXML to provide rowset consisting of customer data.
INSERT Customers
SELECT *
FROM OPENXML(@hDoc, N'/ROOT/Customers')
     WITH Customers
-- Use OPENXML to provide rowset consisting of order data.
INSERT Orders
SELECT *
FROM OPENXML(@hDoc, N'//Orders')
     WITH Orders
-- Using OPENXML in a SELECT statement.
SELECT * FROM OPENXML(@hDoc, N'/ROOT/Customers/Orders') with (CustomerID nchar(5) '../@CustomerID', OrderDate datetime)
-- Remove the internal representation of the XML document.
EXEC sp_xml_removedocument @hDoc

Если всё ещё непонятно - сформулируй вопрос более конкретно. Что именно непонятно. Если непонятно, как применить к своей задаче - опиши её. Если делаешь всё из макросов Excel, то VBA работает как с DOM, так и с ADO - никаких ограничений по работе с SQL Server и XML нет - точно знаю, ибо как раз под Excel и писал макросы, работающие как с ADO, так и с XML.
« Последнее редактирование: 30-11-2007 21:46 от Алексей1153++ » Записан

Программировать - значит понимать (К. Нюгард)
Невывернутое лучше, чем вправленное (М. Аврелий)
Многие готовы скорее умереть, чем подумать (Б. Рассел)
PSD
Главный специалист

ru
Offline Offline
Пол: Мужской

« Ответ #7 : 05-08-2004 06:08 » 

Я не понимаю нафик мне XML если я все равно в конечном итоге все делаю селектами.

"Решается либо написанием XSL преобразования" вот с этого момента по подробней,  как  это реализуется и кто(всмысле какое ПО) это будет делать и простой пример такого преобразоваия.
Записан

Да да нет нет все остальное от лукавого.
Dimka
Деятель
Команда клуба

ru
Offline Offline
Пол: Мужской

« Ответ #8 : 05-08-2004 11:12 » 

1. Твои слова:

Цитата: PSD
хочу использовать описание анных средствами XML для обмена данными между сервеом и приложениями.


Я эти слова понимаю так, что тебе требуется xml потоками передавать данные на сервер и читать в таком же виде.

Через for xml ты можешь получить данные в виде xml на клиенте с сервера.
Через openxml ты можешь передать данные в виде xml с клиента на сервер.

Имхо, задача решена. Если ты имеешь ввиду нечто иное, сформулируй пожалуйста более точно, что ты хочешь.

2. У тебя наверняка свой формат xml документа. xslt - средство преобразования xml документов. И эта тема несколько иная, большая и к базам данных не относящаяся - лучше создай отдельную тему в другом разделе форума.
Записан

Программировать - значит понимать (К. Нюгард)
Невывернутое лучше, чем вправленное (М. Аврелий)
Многие готовы скорее умереть, чем подумать (Б. Рассел)
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines