=> Главная База Знаний Xslt Преобразование xml в реляционную базу данных


Преобразование xml в реляционную базу данных

Преобразование XML в реляционную базу данных

При обсуждении дополнительных возможностей XSLT стоит упомянуть элементы расширения SQL процессора Saxon. Через драйвер Java Database Connectivity (JDBC) можно работать с реляционными базами данных. Мы уже рассмотрели преобразования из XML в XML, в простой текст, в RTF, в JavaScript и т.д. Теперь пришла очередь преобразованию XML в реляционную базу данных.

РАБОТА С ИНТЕРПРЕТИРУЕМЫМ SAXON

Обратите внимание: для связи с базами данных через JDBC нельзя использовать исполняемый файл для Windows saxon.exe. Нужно запустить реализующий Saxon класс Java com.id.saxon.StyleSheet, как я сделаю в конце примера. 

В примере я передам данные

planets.xml
в базу данных формата Microsoft Access
planets.mdb
. Если вы хотите повторить пример, создайте этот файл базы данных, в нем — таблицу
planets
с четырьмя текстовыми полями
Name
,
Mass
,
Radius
и
Day
, а оставшуюся часть файла оставьте пустой. В Windows я зарегистрирую этот файл базы данных в качестве источника ODBC с именем «planets» через значок Data Sources (ODBC) (Источники данных (ODBC)) в панели управления (в Windows 2000 он расположен в панели управления в папке Administrative Tools (Администрирование)). При запуске пример считает данные планет из
planets.xml
и добавит их в файл базы данных,
planets.mdb
.

Для подключения к этой базе данных через JDBC я применил элемент

<sql:connect>
процессора Saxon. Префикс пространства имен
sql
определяется в Saxon следующим образом:

<xsl:stylesheet

 xmlns:sql="http://icl.com/saxon/extensions/com.icl.saxon.sql.SQLElementFactory"

 xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.1">

 .

 .

 .

Для фактического подключения к источнику данных

planets
служит элемент расширения
<sql:connect>
с атрибутами
database
,
user
,
password
и
driver
. Для работы через JDBC установите атрибут
driver
в «
sun.jdbc.odbc.JdbcOdbcDriver
», атрибут
database
— в источник данных
ODBC
, «
jdbc:odbc:planets
», а атрибуты
user
и
password
— в имя пользователя и пароль, нужные для подключения к базе данных. Здесь нам не требуется задавать имя пользователя и пароль, но я задал этим параметрам шаблонные значения, так как они требуются в большинстве приложений баз данных:

<xsl:stylesheet

 xmlns:sql="http://icl.com/saxon/extensions/com.icl.saxon.sql.SQLElementFactory"

 xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.1">

 <xsl:param name="database" select="'jdbc:odbc:planets'"/>

 <xsl:param name="user"/>

 <xsl:param name="password"/>

 <xsl:template match="PLANETS">

  <sql:connect database="{$database}" user="{$user}"

   password="{$password}" driver="sun.jdbc.odbc.JdbcOdbcDriver"

   xsl:extension-element-prefixes="sql"/>

  <xsl:apply-templates select="PLANET"/>

 </xsl:template>

 .

 .

 .

Затем я подключаюсь к источнику данных

planets
. Я хочу вставить в базу данных данные из каждого элемента
<PLANET>
, для чего я создаю новый шаблон, который выбирает элементы
<PLANET>
и вставляет данные в таблицу
planets
базы данных при помощи элемента Saxon
<sql:insert>
:

<xsl:stylesheet

 xmlns:sql="http://icl.com/saxon/extensions/com.icl.saxon.sql.SQLElementFactory"

 xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.1">

 .

 .

 .

 <xsl:template match="PLANETS">

  <sql:connect database="{$database}" user="{$user}"

   password="{$password}" driver="sun.jdbc.odbc.JdbcOdbcDriver"

   xsl:extension-element-prefixes="sql"/>

  <xsl:apply-templates select="PLANET"/>

 </xsl:template>


 <xsl:template match="PLANET">

  <sql:insert table="planets" xsl:extension-element-prefixes="sql">

   .

   .

   .

  </sql:insert>

 </xsl:template>

</xsl:stylesheet>

Элемент

<sql:insert>
вставляет в базу данных новую запись. Чтобы присвоить ее полям новые данные, используйте элемент
<sql:column>
, установив его атрибут name в имя столбца, в который вы хотите записать данные, и присвоив эти данные атрибуту
select
:

<xsl:stylesheet

 xmlns:sql="http://icl.com/saxon/extensions/com.icl.saxon.sql.SQLElementFactory"

 xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.1">

 .

 .

 .

 <xsl:template match="PLANET">

  <sql:insert table="planets" xsl:extension-element-prefixes="sql">

   <sql:column name="Name" select="NAME"/>

   <sql:column name="Mass" select="MASS"/>

   <sql:column name="Radius" select="RADIUS"/>

   <sql:column name="Day" select="DAY"/>

  </sql:insert>

 </xsl:template>

</xsl:stylesheet>

В идеале этого должно быть достаточно, но при работе с самым последним драйвером Access в конце операции Saxon не сбрасывает все буфера данных. Это значит, что данные о последней планете в

planets.xml
, Земле, не будут отправлены в базу данных. Чтобы сбросить буферы данных, я явно вызываю шаблон
<PLANET>
как именованный шаблон, применяя
<sql:insert>
с данными-заглушкой (листинг 10.11).

Листинг 10.11. Работа с реляционной базой данных

<xsl:stylesheet

 xmlns:sql="http://icl.com/saxon/extensions/com.icl.saxon.sql.SQLElementFactory"

 xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.1">

 <xsl:param name="database" select="'jdbc:odbc:planets'"/>

 <xsl:param name="user"/>

 <xsl:param name="password"/>

 <xsl:template match="PLANETS">

  <sql:connect database="{$database}" user="{$user}"

   password="{$password}" driver="sun.jdbc.odbc.JdbcOdbcDriver"

   xsl:extension-element-prefixes="sql"/>

  <xsl:apply-templates select="PLANET"/>

  <xsl:call-template name="writer"/>

 </xsl:template>


 <xsl:template match="PLANET" name="writer">

  <xsl:choose>

   <xsl:when test="NAME">

    <sql:insert table="planets"

     xsl:extension-element-prefixes="sql">

     <sql:column name="Name" select="NAME"/>

     <sql:column name="Mass" select="MASS"/>

     <sql:column name="Radius" select="RADIUS"/>

     <sql:column name="Day" select="DAY"/>

    </sql:insert>

   </xsl:when>

   <xsl:otherwise>

   <sql:insert table="planets"

    xsl:extension-element-prefixes="sql">

    <sql:column name="Name" select="' '"/>

    <sql:column name="Mass" select="' '"/>

    <sql:column name="Radius" select="' '"/>

    <sql:column name="Day" select="' '"/>

   </sql:insert>

  </xsl:otherwise>

 </xsl:choose>

</xsl:template>

</xsl:stylesheet>

Эта таблица стилей правильно добавляет три записи в базу данных

planets.mdb
: по одной новой записи для каждой из планет. Как я говорил, здесь нельзя использовать готовый исполняемый файл
saxon.exe
, нужно применять класс Java
com.icl.saxon.StyleSheet
. Сначала нужно включить в
classpath
файл
saxon.jar
:

C:\>set classpath=.;c:\saxon\saxon.jar

После этого я могу передать в класс

com.icl.saxon.StyleSheet
файл
planets.xml
и таблицу стилей из листинга 10.11:

C:\>java com.icl.saxon.StyleSheet planets.xml saxonsql.xsl

Теперь все сделано — данные планет вставлены в

planets.mdb
. Результаты применения этой таблицы стилей показаны на 4, где я открыл
planets.mdb
в Microsoft Access. Таким образом, мы рассмотрели преобразование из XML в реляционную базу данных.

Преобразование XML в реляционную базу данных

4. Применение расширений SQL Saxon


Еще один аспект XSLT, в котором вам потребуется программирование, это поддержка XSLT на серверах. В качестве демонстрации далее я преобразую

planets.xml
при помощи
planets.xsl
с использованием активных серверных страниц (Active Server Pages, ASP) фирмы Microsoft, серверных страниц Java (Java Server Pages, JSP) фирмы Sun и сервлетов (servlet) Java, выполняющихся на web-серверах и возвращающих результирующий документ браузеру пользователя.

За недостатком места мы не можем подробно рассмотреть эти технологии, и если вы с ними не знакомы, вы можете получить дополнительную информацию в Интернете (как всегда, URL могут измениться):

• ASP. http://msdn.microsoft.com/workshop/c-frame.htm#/workshop/server/Default.asp (руководство и документация по ASP фирмы Microsoft);

• JSP. http://java.sun.com/products/jsp/ (главная страница Sun, посвященная JSP);

• Сервлеты. http://java.sun.com/products/servlet/ (главная страница Sun, посвященная сервлетам).