Datenwürfel für SuperX
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

395 lines
19 KiB

<?xml version="1.0" encoding="UTF-8"?>
<!--<!DOCTYPE module SYSTEM "../../../conf/superx-module.dtd">-->
<module name="xcube" version="0.1" sachgebiet_id="1000" sachgebiet="xcube" systeminfo_id="1000" system="xcube" thema="xCubes" thema_parent="">
<database name="superx" version="2.1" system="superx">
<table name="xcube" thema="Kreuztabellen" typ="Datentabelle" caption="Kreuztabellen">
<columns>
<column name="tid" type ="SERIAL" size ="" default ="" notnull ="true" isKey="true" description=""><comment>Primärschlüssel</comment></column>
<column name="uniquename" type ="VARCHAR" size ="255" default ="" notnull ="false" description="Schlüssel"><comment>nur nachrichtlicher Schlüssel für den Würfel</comment></column>
<column name="name" type ="VARCHAR" size ="255" default ="" notnull ="false" description="Name"><comment>Bezeichnung des Würfels</comment></column>
<column name="sachgebiet" type ="INTEGER" size ="" default ="" notnull ="true" description=""><comment>Sachgebietszuordnung</comment></column>
<column name="table_name" type ="VARCHAR" size ="255" default ="" notnull ="false" description="Faktentabelle"><comment>Faktentabelle</comment></column>
<column name="maskeninfo_id" type ="INTEGER" size ="10" default ="" notnull ="true" description="Maske"><comment>tid der Würfelmaske</comment></column>
<column name="restriction" type ="TEXT" size ="" default ="" notnull ="false" description="Einschränkung"><comment> (where-Bedingung) des Würfels</comment></column>
</columns>
</table>
<table name="xcube_kennzahl" thema="Kreuztabellen" typ="Datentabelle" caption="Kennzahlen Kreuztabellen">
<columns>
<column name="tid" type ="SERIAL" size ="" default ="" notnull ="true" isKey="true" description=""><comment>Primärschlüssel</comment></column>
<column name="maskeninfo_id" type ="INTEGER" size ="10" default ="" notnull ="true" description="Maske"><comment>tid der Würfelmaske</comment></column>
<column name="apnr" type ="VARCHAR" size ="255" default ="" notnull ="true" description="Schlüssel"><comment>Schlüssel</comment></column>
<column name="name" type ="VARCHAR" size ="255" default ="" notnull ="true" description="Name"><comment>Bezeichnung</comment></column>
<column name="aggrfunction" type ="TEXT" size ="" default ="" notnull ="true" description="Aggregationsfunktion"><comment> wie sum(summe) oder count(*)</comment></column>
<column name="restriction" type ="TEXT" size ="" default ="" notnull ="false" description="Einschränkung"><comment>Optional zusätzliche Einschränkung (where-Bedingung)</comment></column>
<column name="datatype" type ="VARCHAR" size ="255" default ="" notnull ="false" description="Datentyp"><comment>optional Datentyp falls nicht decimal</comment></column>
<column name="is_default" type ="SMALLINT" size ="5" default ="" notnull ="false" description="Kennzahl default"><comment>Soll die Kennzahl default bei der Auswahl sein</comment></column>
<column name="sortnr" type ="SMALLINT" size ="5" default ="" notnull ="false" description="Sortiernr."><comment>Sortierung für das Auswahlfeld Kennzahl</comment></column>
</columns>
</table>
<table name="xcube_dimconfig" thema="Kreuztabellen" typ="Schlüsseltabelle" caption="Dimensionseigenschaften">
<columns>
<column name="tid" type ="SERIAL" size ="" default ="" notnull ="true" isKey="true" description=""><comment>Primärschlüssel</comment></column>
<column name="maskeninfo_id" type ="INTEGER" size ="10" default ="" notnull ="true" description="Maske"><comment>Nummer der Würfelmaske</comment></column>
<column name="name" type ="VARCHAR" size ="255" default ="" notnull ="true" description="Name"><comment>Name der Spalte in der Faktentabelle</comment></column>
<column name="caption" type ="VARCHAR" size ="255" default ="" notnull ="true" description="Beschriftung"><comment>Label für die Dimension in der Darstellung, bei Sichten-Dimensionen muss Feldnamen auf der Maske entsprechen</comment></column>
<!-- <column name="generic_dimension" type ="VARCHAR" size ="255" default ="" notnull ="false" /> -->
<column name="is_sicht" type ="SMALLINT" size ="5" default ="0" notnull ="true" description="Sicht"><comment>Ist die Dimension keine Sicht (0), ein SuperX-Sicht Feld(1) oder eine Sicht mit SQL (2)</comment></column>
<column name="calc_gesamt" type ="SMALLINT" size ="5" default ="1" notnull ="true" description="Gesamtwert"><comment>Soll eine Gesamtwert dargestellt werden?</comment></column>
<column name="is_rowdim" type ="SMALLINT" size ="5" default ="1" notnull ="true" description="Zeilendimension"><comment>Soll die Dimension in den Zeilen darstellbar sein</comment></column>
<column name="is_secondrowdim" type ="SMALLINT" size ="5" default ="1" notnull ="true" description="Zweite Zeilendimension"><comment>Soll die Dimension als 2.Dim in den Zeilen darstellbar sein</comment></column>
<column name="is_rowdefault" type ="SMALLINT" size ="5" default ="0" notnull ="true" description="Zeilen-default"><comment>Soll die Dimension als Zeilen-default auf der Maske ausgewählt sein</comment></column>
<column name="is_coldim" type ="SMALLINT" size ="5" default ="1" notnull ="true" description="Spaltendimension"><comment>Soll die Dimension in den Spalten darstellbar sein</comment></column>
<column name="is_secondcoldim" type ="SMALLINT" size ="5" default ="1" notnull ="true" description="Zweite Spaltendimension"><comment>Soll die Dimension als 2.Dim in den Spalten darstellbar sein</comment></column>
<column name="is_coldefault" type ="SMALLINT" size ="5" default ="0" notnull ="true" description="Spalten-default"><comment>Soll die Dimension als Spalten-default auf der Maske ausgewählt sein</comment></column>
<column name="attrib_nachbearbeitung" type ="TEXT" size ="" default ="" notnull ="false" description="Nachbearbeiten eines Attributs"><comment></comment></column>
<!-- <column name="specific_restriction" type ="VARCHAR" size ="255" default ="" notnull ="false" />
<column name="specific_2ndcol_restriction" type ="VARCHAR" size ="255" default ="" notnull ="false" />-->
<column name="is_virtual" type ="SMALLINT" size ="" default ="0" notnull ="true" description="Virtuell"><comment>Ist es eine virtuelle Spalte, die selbst in der Faktentabelle nicht vorhanden ist</comment></column>
<column name="vcsql" type ="TEXT" size ="" default ="" notnull ="false" description="SQL"><comment>SQL zum Setzen der virtuellen Spalte</comment></column>
<column name="foreignkey_tab" type="VARCHAR" size="255" default="" notnull="false" description="Fremdschlüssel Tabelle"><comment></comment></column>
<column name="foreignkey_col" type="VARCHAR" size="255" default="" notnull="false" description="Fremdschlüssel Feld (Schlüssel)" ><comment></comment></column>
<column name="foreignkey_cap" type="VARCHAR" size="255" default="" notnull="false" description="Fremdschlüssel Feld (Bezeichnung)"><comment></comment></column>
<column name="foreignkey_cond" type="VARCHAR" size="255" default="" notnull="false" description="Zusätzliche Bedingung"><comment> für Fremdschlüssel</comment></column>
<column name="foreignkey_func" type="VARCHAR" size="255" default="" notnull="false" description="Zusätzliche Funktion"><comment> für Fremdschlüssel</comment></column>
<column name="sortfield" type ="VARCHAR" size ="255" default ="" notnull ="false" description="Sortierfeld"><comment>Name des Sortierfelds für Nicht-Sichten</comment></column>
</columns>
<indexes>
<index name="ix_xc_dc">
<index-column name="maskeninfo_id" />
</index>
</indexes>
<primaryKeys><rs>
</rs></primaryKeys>
<foreignKeys></foreignKeys>
<importedKeys></importedKeys>
<privileges><rs>
</rs></privileges>
</table>
<table name="xcube_dims" thema="Kreuztabellen" typ="Datentabelle" caption="Dimensionen">
<columns>
<column name="id" type ="VARCHAR" size ="255" default ="" notnull ="false" description=""><comment>ID für die Art der Dimension</comment></column>
<column name="apnr" type ="VARCHAR" size ="255" default ="" notnull ="false" description="Schlüssel"><comment>Einzelner Schlüssel</comment></column>
<column name="parent" type ="VARCHAR" size ="255" default ="" notnull ="false" description="Parent"><comment>optional parent</comment></column>
<column name="name" type ="VARCHAR" size ="255" default ="" notnull ="false" description="Name"><comment>Bezeichnung des Eintrags</comment></column>
<column name="strukturstr" type ="VARCHAR" size ="2000" default ="" notnull ="false" description="Strukturmerkmal (String)"/>
<column name="strukturint" type ="INTEGER" size ="" default ="" notnull ="false" description="Strukturmerkmal (INT)"/>
<column name="sort1" type ="INTEGER" size ="10" default ="" notnull ="false" description="Sortierfeld"><comment></comment></column>
</columns>
<indexes>
<index name="ix_xc_dim11">
<index-column name="id" />
</index>
</indexes>
<primaryKeys><rs>
</rs></primaryKeys>
<foreignKeys></foreignKeys>
<importedKeys></importedKeys>
<privileges><rs>
</rs></privileges>
</table>
<functions>
</functions>
<views>
<view name="xcube_wohnort_staat" caption="Wohnorte/Staaten">
<description>View Wohnorte nach Bundesland und Staaten</description>
<columns>
<column name="druck" type="VARCHAR" size ="255" default ="" notnull ="true" />
<column name="apnr" type="CHAR" size ="10" default ="" notnull ="false" />
<column name="parent" type="CHAR" size ="10" default ="" notnull ="false" />
</columns>
<sql dbsystem=""><![CDATA[select 'alle'::varchar(255) as druck ,
'alle'::char(10) as apnr,
null as parent
from xdummy
union
select 'Deutschland'::varchar(255) as druck ,
'0'::char(10) as apnr,
'alle' as parent
from xdummy
union select druck,
apnr,
'0' as parent
from cifx where key=8
union select druck,
'' || val(astat) as apnr ,
bund_apnr as parent
from cifx where key=11
union select 'Ausland' druck , '1' apnr, 'alle' as parent from xdummy
union select druck,apnr,'1' from cifx where key=747 and parent is not null
union select druck, case when astat='' or astat is null then apnr else astat end ,
case when bund_apnr='' or bund_apnr='---' or bund_apnr is null then '-9999' else bund_apnr end from cifx where key=12 and apnr != 'D'
union
select 'unbekannt' druck, '-9999' apnr, 'alle' as parent from xdummy;
]]></sql>
</view>
<view name="xcube_hoererstatus" caption="Wohnorte/Staaten">
<description>View Hörerstatus</description>
<columns>
<column name="druck" type="VARCHAR" size ="255" default ="" notnull ="true" />
<column name="apnr" type="CHAR" size ="10" default ="" notnull ="false" />
<column name="parent" type="CHAR" size ="10" default ="" notnull ="false" />
</columns>
<sql dbsystem=""><![CDATA[select 'Alle'::varchar(255) as druck,'A' as apnr,null::char(10) as parent
from xdummy
union
select 'Haupt-/Nebenhörer'::varchar(255) as druck,'A1' as apnr,'A'::char(10) as parent
from xdummy
union select druck::varchar(255), apnr, 'A1'::char(10) as parent from cifx where key= 613 and astat='1'
union
select 'Zweithörer'::varchar(255) as druck,'A2' as apnr,'A'::char(10) as parent
from xdummy
union select druck::varchar(255), apnr, 'A2'::char(10) as parent from cifx where key= 613 and astat='2'
union
select 'Deutschkurs/Studienkolleg'::varchar(255) as druck,'A3' as apnr,'A'::char(10) as parent
from xdummy
union select druck::varchar(255), apnr, 'A3'::char(10) as parent from cifx where key= 613 and astat='3'
union
select 'Gasthörer'::varchar(255) as druck,'A4' as apnr,'A'::char(10) as parent
from xdummy
union select druck::varchar(255), apnr, 'A4'::char(10) as parent from cifx where key= 613 and astat='4'
union
select 'Sonstige'::varchar(255) as druck,'A99' as apnr,'A'::char(10) as parent
from xdummy
union select druck::varchar(255), apnr, 'A99'::char(10) as parent from cifx where key= 613 and astat not in ('1','2','3','4')
]]></sql>
</view>
</views>
<themen>
<thema name="Administration xCubes"
parent="xCubes">Abfragen zur Administration von xCubes </thema>
</themen>
<masken>
<maske tid="21030" name="Datenwürfel verwalten" thema="Administration xCubes">
<src>
<path>$XCUBE_PFAD/masken</path>
</src>
</maske>
<maske tid="21000" name="Studierende XCUBE" thema="xCubes">
<src>
<path>$XCUBE_PFAD/masken</path>
<dbsystem>POSTGRES</dbsystem>
</src>
</maske>
<maske tid="21100" name="Abschlussprüfungen XCUBE" thema="xCubes">
<src>
<path>$XCUBE_PFAD/masken</path>
<dbsystem>POSTGRES</dbsystem>
</src>
</maske>
<maske tid="21500" name="Primärkosten XCUBE" thema="xCubes">
<src>
<path>$XCUBE_PFAD/masken</path>
<dbsystem>POSTGRES</dbsystem>
</src>
</maske>
</masken>
<data-integrity>
<!--xcube-->
<relation from="sachgebiete" to="xcube" delete="FALSE"
displayType="select" visibleFields="name" format="%s">
<relation-column from="tid" to="sachgebiet" />
</relation>
<relation from="maskeninfo" to="xcube" delete="FALSE"
displayType="select" visibleFields="name" format="%s">
<relation-column from="tid" to="maskeninfo_id" />
</relation>
<!--xcube_dimconfig-->
<relation from="maskeninfo" to="xcube_dimconfig" delete="FALSE"
displayType="select" visibleFields="name" format="%s">
<relation-column from="tid" to="maskeninfo_id" />
</relation>
<!--xcube_kennzahl-->
<relation from="maskeninfo" to="xcube_kennzahl" delete="FALSE"
displayType="select" visibleFields="name" format="%s">
<relation-column from="tid" to="maskeninfo_id" />
</relation>
</data-integrity>
</database>
<install>
<install-step>
<action error="cont">
<nativeaction sql="" scriptfile="$XCUBE_PFAD/schluesseltabellen/xcube_install.sql" database=""/>
<nativeaction sql="" scriptfile="$XCUBE_PFAD/schluesseltabellen/xcube_install_restrictions.sql" database=""/>
<nativeaction sql="" scriptfile="$XCUBE_PFAD/schluesseltabellen/xcube_dims_install.sql" database=""/>
<nativeaction sql="" scriptfile="$XCUBE_PFAD/schluesseltabellen/sichten_fuellen.sql" database=""/>
</action>
</install-step>
</install>
<upgrade>
<upgrade-step>
<action error="cont">
<nativeaction sql="" scriptfile="$XCUBE_PFAD/schluesseltabellen/xcube_install.sql" database=""/>
<nativeaction sql="" scriptfile="$XCUBE_PFAD/schluesseltabellen/xcube_install_restrictions.sql" database=""/>
<nativeaction sql="" scriptfile="$XCUBE_PFAD/schluesseltabellen/xcube_dims_install.sql" database=""/>
<nativeaction sql="" scriptfile="$XCUBE_PFAD/schluesseltabellen/sichten_fuellen.sql" database=""/>
</action>
</upgrade-step>
</upgrade>
<etl>
<etl-step name="Aktualisieren der xcube-Tabellen" type="trans">
<action error="stop">
<nativeaction sql="" scriptfile="$XCUBE_PFAD/schluesseltabellen/xcube_dims_install.sql" database=""/>
</action>
</etl-step>
</etl>
<dbforms>
<form name="xcube_list"
table="xcube"
path="/edit/xcube/xcube_list.jsp"
followUp=""
caption="Würfel verwalten"
orderBy="name"
gotoHt=""
helpfile=""
maxRows="*"
mode="full">
<description>In diesem Formular können Sie Würfel verwalten. Im Details-Formular können Sie Eigenschaften zuordnen.</description>
<filters>
</filters>
<field-selection complete="false" />
<customfield name="tid" nullFieldValue="" />
<customfield name="name" nullFieldValue="" visibleSize="30" />
<customfield name="uniquename" nullFieldValue="" visibleSize="30" />
<customfield type="link" name="Details" path="/superx/edit/xcube/xcube_edit.jsp" linkid="tid"/>
</form>
<form name="xcube_edit"
table="xcube"
path="/edit/xcube/xcube_edit.jsp"
followUp=""
caption="Würfel bearbeiten"
orderBy="name"
gotoHt=""
helpfile=""
maxRows="1"
mode="full">
<description>In diesem Formular können Sie Würfel verwalten.</description>
<filters>
<filter mandatory="true" type="equals">tid</filter>
</filters>
<field-selection complete="false" />
<customfield name="tid" />
<customfield name="name" visibleSize="50" nullFieldValue="" />
<customfield name="uniquename" visibleSize="20" nullFieldValue="" />
<customfield name="table_name" visibleSize="20" nullFieldValue="" />
<customfield name="maskeninfo_id" visibleSize="10" nullFieldValue="" />
<customfield name="sachgebiet" visibleSize="80" nullFieldValue="" />
<customfield name="restriction" visibleSize="80" nullFieldValue="" />
</form>
<form name="xcube_dims_list"
table="xcube_dims"
path="/edit/xcube/xcube_dims_list.jsp"
followUp=""
caption="Dimensionsinhalte verwalten"
orderBy="name"
gotoHt=""
helpfile=""
maxRows="*"
mode="full">
<description>In diesem Formular können Sie Dimensionsinhalte verwalten. Im Details-Formular können Sie Eigenschaften zuordnen.</description>
<filters>
<filter mandatory="true" type="equals">id</filter>
</filters>
<field-selection complete="false" />
<customfield name="name" nullFieldValue="" visibleSize="30" />
<customfield name="apnr" nullFieldValue="" visibleSize="30" />
<customfield name="parent" nullFieldValue="" visibleSize="30" />
<customfield name="strukturstr" nullFieldValue="" visibleSize="30" />
<customfield name="strukturint" nullFieldValue="" visibleSize="30" />
<customfield name="sort1" nullFieldValue="" visibleSize="30" />
</form>
<form name="xcube_dimconfig_list"
table="xcube_dimconfig"
path="/edit/xcube/xcube_dimconfig_list.jsp"
followUp=""
caption="Dimensionen verwalten"
orderBy="name"
gotoHt=""
helpfile=""
maxRows="*"
mode="full">
<description>In diesem Formular können Sie Dimensionen verwalten. Im Details-Formular können Sie Eigenschaften zuordnen.</description>
<filters>
</filters>
<field-selection complete="false" />
<customfield name="tid" nullFieldValue="" />
<customfield name="name" nullFieldValue="" visibleSize="30" />
<customfield name="caption" nullFieldValue="" visibleSize="30" />
<customfield type="link" name="Details" path="/superx/edit/xcube/xcube_dimconfig_edit.jsp" linkid="tid"/>
</form>
<form name="xcube_dimconfig_edit"
table="xcube_dimconfig"
path="/edit/xcube/xcube_dimconfig_edit.jsp"
followUp=""
caption="Dimensionen bearbeiten"
orderBy="name"
gotoHt=""
helpfile=""
maxRows="1"
mode="full">
<description>In diesem Formular können Sie Dimensionen verwalten.</description>
<filters>
<filter mandatory="true" type="equals">tid</filter>
</filters>
<field-selection complete="true" />
</form>
<form name="xcube_kennzahl_list"
table="xcube_kennzahl"
path="/edit/xcube/xcube_kennzahl_list.jsp"
followUp=""
caption="Kennzahlen verwalten"
orderBy="name"
gotoHt=""
helpfile=""
maxRows="*"
mode="full">
<description>In diesem Formular können Sie Kennzahlen verwalten. Im Details-Formular können Sie Eigenschaften zuordnen.</description>
<filters>
</filters>
<field-selection complete="false" />
<customfield name="tid" nullFieldValue="" />
<customfield name="name" nullFieldValue="" visibleSize="30" />
<customfield name="apnr" nullFieldValue="" visibleSize="30" />
<customfield type="link" name="Details" path="/superx/edit/xcube/xcube_kennzahl_edit.jsp" linkid="tid"/>
</form>
<form name="xcube_kennzahl_edit"
table="xcube_kennzahl"
path="/edit/xcube/xcube_kennzahl_edit.jsp"
followUp=""
caption="Kennzahlen bearbeiten"
orderBy="name"
gotoHt=""
helpfile=""
maxRows="1"
mode="full">
<description>In diesem Formular können Sie Kennzahlen verwalten.</description>
<filters>
<filter mandatory="true" type="equals">tid</filter>
</filters>
<field-selection complete="true" />
</form>
</dbforms>
</module>