Получить базу данных MS SQL или структуру таблицы в XML
Есть ли способ экспортировать схему базы данных в правильно сформированный XML MS 2000 SQL Server. Я ищу только структуру, а не данные, и чем детальнее, тем лучше. XML может использоваться в процессах миграции. Я больше знаком с MySQL, чем с SQL Server, поэтому, пожалуйста, будьте внимательны, если у вас есть время.
Спасибо
3 ответа
Как насчет использования представлений информационной схемы или базовых системных таблиц, таких как sysobjects, syscolumns, и последующего использования предложения FOR XML для выделения некоторого xml. Вот кое-что, чтобы вы начали:
SELECT o.name as table_name
,c.name as column_name
,t.name as column_type
,t.length as column_length from sysobjects o
inner join syscolumns c on o.id=c.id
inner join systypes t on c.xtype=t.xtype
where o.xtype='u'
FOR XML RAW
Я написал приложение ( dbscript), которое генерирует XML-представление схемы базы данных (или отдельных объектов схемы) после импорта схемы из базы данных или загрузки файла SQL DDL.
Просто чтобы показать, что это возможно, я не могу рассказать вам, как создать код, который будет это делать, но с некоторым программным обеспечением, созданным моим другом, схема.xml выглядит примерно так. Может быть, это поможет вам создать собственный код?
<table enabled="true" name="Users">
<field name="i_user_id" size="10" type="INTEGER"/>
<field name="c_user_login" size="32" type="VARCHAR"/>
<field name="c_user_pwd" size="32" type="VARCHAR"/>
<field name="c_user_session" size="40" type="VARCHAR"/>
<field name="c_user_name" size="200" type="VARCHAR"/>
<field name="d_stamp_" size="19" type="DATETIME"/>
<index name="Users2CID_0" unique="true" using="OTHER">
<field direction="ASCENDING" name="i_user_id" ordinal="1"/>
</index>
<index name="Users2_1_idx" unique="false" using="OTHER">
<field direction="ASCENDING" name="c_user_login" ordinal="1"/>
</index>
<index name="Users2_3_idx" unique="false" using="OTHER">
<field direction="ASCENDING" name="c_user_session" ordinal="1"/>
</index>
<index name="Users2_4_idx" unique="false" using="OTHER">
<field direction="ASCENDING" name="c_user_name" ordinal="1"/>
</index>
<index name="Users2_8_idx" unique="false" using="OTHER">
<field direction="ASCENDING" name="c_flag_" ordinal="1"/>
</index>
<index name="Users2_9_idx" unique="false" using="OTHER">
<field direction="ASCENDING" name="d_stamp_" ordinal="1"/>
</index>
</table>
И тогда файл данных выглядит так:
users.dat
i_user_id ( ,10,INTEGER,true,true,true) c_user_login ( ,32,VARCHAR,true,true,true) c_user_pwd ( ,32,VARCHAR,true,true,true) c_user_session ( ,40,VARCHAR,true,true,true) c_user_name ( ,200,VARCHAR,true,true,true) d_stamp_ ( ,19,DATETIME,true,true,true)
1 CUSER Null -1 CUser 2010-02-16 23:06:38.0
2 admin X032343fZdYdgrtueuILPmQ== -1 Admin User 2009-12-03 00:13:30.0