Come si uniscono due variabili XML in SQL Server (2005/2008)?
-
30-10-2019 - |
Domanda
Avanti: ho già letto Questo thread di stackoverflow E non affronta la ritenzione di profondità di cui ho bisogno.
Voglio creare un documento XML che contenga gli oggetti di definizione dei dati per un singolo database, utilizzando la gerarchia:
<CATALOG>
<SCHEMA>
<TABLE>
<TableExtendedProperty/>
<TableExtendedProperty/>
<COLUMN>
<ColumnExtendedProperty/>
<ColumnExtendedProperty/>
</COLUMN>
<COLUMN>
<ColumnExtendedProperty/>
<ColumnExtendedProperty/>
</COLUMN>
...etc...
</TABLE>
...etc...
</SCHEMA>
...etc...
</CATALOG>
Ho due domande costruite.
- Si crea la gerarchia a livello della tabella con gli elementi di tableextendproperty per bambini
- Si crea la gerarchia a livello di colonna con gli elementi infantile columnextedproperty
Il risultato XML (abbreviato) per ciascuna query è fornito di seguito.
Devo (a) unire queste due variabili XML in una singola variabile XML o (b) costruire una query diversa che produce il risultato desiderato.
Cosa puoi consigliare?
Codice sorgente
Query creating hierarchy to the TABLE level with child TableExtendedProperty elements
SELECT DISTINCT
_Catalog.TABLE_CATALOG
,_Schema.TABLE_SCHEMA
,_Table.TABLE_NAME
,_TableExtProp.name as TableExtPropName
,_TableExtProp.value as TableExtPropValue
from information_schema.tables _Schema
INNER JOIN information_schema.columns _Catalog ON _Catalog.TABLE_CATALOG=_Schema.TABLE_CATALOG
INNER JOIN information_schema.tables _Table ON _Table.TABLE_NAME=_Schema.TABLE_NAME
LEFT OUTER join sys.extended_properties _TableExtProp on _TableExtProp.major_id=OBJECT_ID(_Schema.TABLE_SCHEMA + '.' + _Table.TABLE_NAME) and _TableExtProp.minor_id=0
FOR XML AUTO
RESULT
<_Catalog TABLE_CATALOG="A">
<_Schema TABLE_SCHEMA="B">
<_Table TABLE_NAME="C">
<_TableExtProp TableExtPropName="TP1" TableExtPropValue="Lorem" />
<_TableExtProp TableExtPropName="TP2" TableExtPropValue="Ipsum" />
</_Table>
<_Table TABLE_NAME="D">
<_TableExtProp TableExtPropName="TP1" TableExtPropValue="Borem" />
</_Table>
</_Schema>
<_Schema TABLE_SCHEMA="E">
<_Table TABLE_NAME="F">
</_Table>
<_Table TABLE_NAME="G">
<_TableExtProp TableExtPropName="TP1" TableExtPropValue="Corem" />
</_Table>
</_Schema>
</_Catalog>
Query creating hierarchy to the COLUMN level with child ColumnExtendedProperty elements
SELECT DISTINCT
_Catalog.TABLE_CATALOG
,_Schema.TABLE_SCHEMA
,_Table.TABLE_NAME
,_Col.COLUMN_NAME
,_ColumnExtProp.name as ColumnExtPropName
,_ColumnExtProp.value as ColumnExtPropValue
from information_schema.tables _Schema
INNER JOIN information_schema.columns _Catalog ON _Catalog.TABLE_CATALOG=_Schema.TABLE_CATALOG
INNER JOIN information_schema.tables _Table ON _Table.TABLE_NAME=_Schema.TABLE_NAME
INNER JOIN information_schema.columns _Col ON _col.Table_name=_Table.Table_Name /* need a schema comparison also */
LEFT OUTER join sys.extended_properties _ColumnExtProp on _ColumnExtProp.major_id=OBJECT_ID(_Schema.TABLE_SCHEMA + '.' + _Table.TABLE_NAME) and _ColumnExtProp.minor_id=_Col.ORDINAL_POSITION
FOR XML AUTO
RESULT
<_Catalog TABLE_CATALOG="A">
<_Schema TABLE_SCHEMA="B">
<_Table TABLE_NAME="C">
<_Col COLUMN_NAME="AXA">
<_ColumnExtProp ColumnExtPropName="CP1" ColumnExtPropValue="WWW" />
<_ColumnExtProp ColumnExtPropName="CP2" ColumnExtPropValue="WWW" />
</_Col>
<_Col COLUMN_NAME="FRDCQ">
<_ColumnExtProp ColumnExtPropName="CP1" ColumnExtPropValue="EQW" />
</_Col>
</_Table>
<_Table TABLE_NAME="D">
<_Col COLUMN_NAME="PolicyTypeCode">
<_ColumnExtProp ColumnExtPropName="CP3" ColumnExtPropValue="SAS" />
</_Col>
</_Table>
</_Schema>
<_Schema TABLE_SCHEMA="E">
<_Table TABLE_NAME="F">
<_Col COLUMN_NAME="BAXA">
</_Col>
<_Col COLUMN_NAME="BAFA">
<_ColumnExtProp ColumnExtPropName="CP1" ColumnExtPropValue="WEW" />
</_Col>
</_Table>
<_Table TABLE_NAME="G">
<_Col COLUMN_NAME="BAFA">
<_ColumnExtProp ColumnExtPropName="CP1" ColumnExtPropValue="WTTEW" />
</_Col>
</_Table>
</_Schema>
</_Catalog>
DESIRED RESULT
<_Catalog TABLE_CATALOG="A">
<_Schema TABLE_SCHEMA="B">
<_Table TABLE_NAME="C">
<_TableExtProp TableExtPropName="TP1" TableExtPropValue="Lorem" />
<_TableExtProp TableExtPropName="TP2" TableExtPropValue="Ipsum" />
<_Col COLUMN_NAME="AXA">
<_ColumnExtProp ColumnExtPropName="CP1" ColumnExtPropValue="WWW" />
<_ColumnExtProp ColumnExtPropName="CP2" ColumnExtPropValue="WWW" />
</_Col>
<_Col COLUMN_NAME="FRDCQ">
<_ColumnExtProp ColumnExtPropName="CP1" ColumnExtPropValue="EQW" />
</_Col>
</_Table>
<_Table TABLE_NAME="D">
<_TableExtProp TableExtPropName="TP1" TableExtPropValue="Borem" />
<_Col COLUMN_NAME="PolicyTypeCode">
<_ColumnExtProp ColumnExtPropName="CP3" ColumnExtPropValue="SAS" />
</_Col>
</_Table>
</_Schema>
<_Schema TABLE_SCHEMA="E">
<_Table TABLE_NAME="F">
<_Col COLUMN_NAME="BAXA">
</_Col>
<_Col COLUMN_NAME="BAFA">
<_ColumnExtProp ColumnExtPropName="CP1" ColumnExtPropValue="WEW" />
</_Col>
</_Table>
<_Table TABLE_NAME="G">
<_TableExtProp TableExtPropName="TP1" TableExtPropValue="Corem" />
<_Col COLUMN_NAME="BAFA">
<_ColumnExtProp ColumnExtPropName="CP1" ColumnExtPropValue="WTTEW" />
</_Col>
</_Table>
</_Schema>
</_Catalog>
Nessuna soluzione corretta
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a dba.stackexchange