relmdVendorAccess.xsd 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!--
  3. Licensed Materials - Property of IBM
  4. IBM Cognos Products: relmd
  5. (C) Copyright IBM Corp. 2008, 2015
  6. US Government Users Restricted Rights - Use, duplication or disclosure restricted by GSA ADP Schedule Contract with IBM Corp.
  7. -->
  8. <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns="http://www.ibm.com/xmlns/prod/cognos/relmd/1/0" targetNamespace="http://www.ibm.com/xmlns/prod/cognos/relmd/1/0" elementFormDefault="qualified" attributeFormDefault="qualified">
  9. <!--
  10. Copyright (C) 2008 Cognos ULC, an IBM Company. All rights reserved.
  11. Cognos (R) is a trademark of Cognos ULC, (formerly Cognos Incorporated).
  12. Relational metadata database extraction rules.
  13. -->
  14. <xs:group name="extractionRulesResultSetProvider">
  15. <xs:choice>
  16. <xs:group ref="sqlAccess"/>
  17. <xs:group ref="genericResultSetProvider"/>
  18. <xs:element name="databaseMetadataJdbcFunction"/>
  19. </xs:choice>
  20. </xs:group>
  21. <xs:group name="catalogGrainFilterableSql">
  22. <xs:sequence>
  23. <xs:element name="catalogGrainObjectSelectionsInclusion" minOccurs="0" maxOccurs="unbounded">
  24. <xs:complexType>
  25. <xs:sequence>
  26. <xs:element name="catalogGrainSelectionsCondition" maxOccurs="unbounded">
  27. <xs:complexType>
  28. <xs:attribute name="schemaExpression"/>
  29. <xs:attribute name="objectExpression"/>
  30. </xs:complexType>
  31. </xs:element>
  32. </xs:sequence>
  33. <xs:attribute name="sqlFragment" type="xs:string" use="required"/>
  34. <xs:attributeGroup ref="whereClauseConditionInsertion"/>
  35. </xs:complexType>
  36. </xs:element>
  37. </xs:sequence>
  38. </xs:group>
  39. <xs:group name="sqlInsertionLocation">
  40. <xs:choice>
  41. <xs:element name="objectSubstitution"/>
  42. </xs:choice>
  43. </xs:group>
  44. <xs:group name="objectSelectionsWhereClauseInsertion">
  45. <xs:choice>
  46. <xs:element name="schemaSelectionsCondition">
  47. <xs:complexType>
  48. <xs:attributeGroup ref="whereClauseConditionInsertion"/>
  49. <xs:attribute name="catalogExpression"/>
  50. <xs:attribute name="schemaExpression" use="required"/>
  51. </xs:complexType>
  52. </xs:element>
  53. <xs:element name="objectSelectionsCondition">
  54. <xs:complexType>
  55. <xs:attributeGroup ref="whereClauseConditionInsertion"/>
  56. <xs:attributeGroup ref="objectSelectionsSqlExpressionMappings"/>
  57. </xs:complexType>
  58. </xs:element>
  59. </xs:choice>
  60. </xs:group>
  61. <xs:attributeGroup name="whereClauseColumns">
  62. <xs:attribute name="catalog" type="xs:string" use="optional" default="CATALOG_NAME"/>
  63. <xs:attribute name="schema" type="xs:string" use="optional" default="SCHEMA_NAME"/>
  64. <xs:attribute name="object" type="xs:string" use="optional" default="OBJECT_NAME"/>
  65. <xs:attribute name="system_flag" type="xs:string" use="optional" default="SYSTEM_FLAG"/>
  66. </xs:attributeGroup>
  67. <xs:attributeGroup name="foreignKeywhereClauseColumns">
  68. <xs:attribute name="catalog" type="xs:string" use="optional" default="FK_CATALOG_NAME"/>
  69. <xs:attribute name="schema" type="xs:string" use="optional" default="FK_SCHEMA_NAME"/>
  70. <xs:attribute name="object" type="xs:string" use="optional" default="FK_OBJECT_NAME"/>
  71. <xs:attribute name="system_flag" type="xs:string" use="optional" default="SYSTEM_FLAG"/>
  72. </xs:attributeGroup>
  73. <xs:attributeGroup name="catalogLevelFilterColumns">
  74. <xs:attribute name="catalogLevelFilterColumn" type="xs:string" use="required"/>
  75. <xs:attribute name="schemaLevelFilterColumn" type="xs:string" use="required"/>
  76. <xs:attribute name="objectLevelFilterColumn" type="xs:string" use="required"/>
  77. </xs:attributeGroup>
  78. <xs:attributeGroup name="schemaLevelFilterColumns">
  79. <xs:attribute name="schemaLevelFilterColumn" type="xs:string" use="required"/>
  80. <xs:attribute name="objectLevelFilterColumn" type="xs:string" use="required"/>
  81. </xs:attributeGroup>
  82. <xs:attributeGroup name="systemObject">
  83. <xs:attribute name="name" type="xs:string"/>
  84. </xs:attributeGroup>
  85. <xs:attributeGroup name="whereClauseConditionInsertion">
  86. <xs:attribute name="insertLocation" use="required">
  87. <xs:simpleType>
  88. <xs:restriction base="xs:NMTOKEN">
  89. <xs:enumeration value="before"/>
  90. <xs:enumeration value="after"/>
  91. </xs:restriction>
  92. </xs:simpleType>
  93. </xs:attribute>
  94. <xs:attribute name="insertPrefix" use="required">
  95. <xs:simpleType>
  96. <xs:restriction base="xs:NMTOKEN">
  97. <xs:enumeration value="WHERE"/>
  98. <xs:enumeration value="AND"/>
  99. </xs:restriction>
  100. </xs:simpleType>
  101. </xs:attribute>
  102. </xs:attributeGroup>
  103. <xs:attributeGroup name="objectSelectionsSqlExpressionMappings">
  104. <xs:attribute name="catalogExpression"/>
  105. <xs:attribute name="schemaExpression"/>
  106. <xs:attribute name="objectExpression"/>
  107. </xs:attributeGroup>
  108. <xs:attributeGroup name="sqlDecorator">
  109. <xs:attribute name="sqlFragment" type="xs:string" use="required"/>
  110. </xs:attributeGroup>
  111. <xs:simpleType name="jdbcMethodType">
  112. <xs:restriction base="xs:NMTOKEN">
  113. <xs:enumeration value="getTables"/>
  114. <xs:enumeration value="getColumns"/>
  115. <xs:enumeration value="getKeys"/>
  116. <xs:enumeration value="getIndexes"/>
  117. <xs:enumeration value="getSynonyms"/>
  118. <xs:enumeration value="getProcedures"/>
  119. <xs:enumeration value="TBD"/>
  120. </xs:restriction>
  121. </xs:simpleType>
  122. <xs:simpleType name="resultColumnIndexValueUndefined">
  123. <xs:restriction base="xs:NMTOKEN">
  124. <xs:pattern value="1"/>
  125. <xs:enumeration value="-1"/>
  126. </xs:restriction>
  127. </xs:simpleType>
  128. <xs:simpleType name="granularityType">
  129. <xs:restriction base="xs:NMTOKEN">
  130. <xs:enumeration value="global"/>
  131. <xs:enumeration value="catalog"/>
  132. <xs:enumeration value="schema"/>
  133. <xs:enumeration value="group"/>
  134. <xs:enumeration value="table"/>
  135. </xs:restriction>
  136. </xs:simpleType>
  137. <xs:simpleType name="resultSchemaColumnIndexType">
  138. <xs:union memberTypes="xs:positiveInteger xs:NMTOKEN"/>
  139. </xs:simpleType>
  140. <xs:simpleType name="resultSetRecordColumnIndexType">
  141. <xs:union memberTypes="xs:positiveInteger xs:NMTOKEN"/>
  142. </xs:simpleType>
  143. <xs:simpleType name="schemaChildObjectNameIndexType">
  144. <xs:restriction base="resultSetRecordColumnIndexType"/>
  145. </xs:simpleType>
  146. <xs:simpleType name="refCatalogNameIndexType">
  147. <xs:restriction base="resultSetRecordColumnIndexType"/>
  148. </xs:simpleType>
  149. <xs:simpleType name="refSchemaNameIndexType">
  150. <xs:restriction base="resultSetRecordColumnIndexType"/>
  151. </xs:simpleType>
  152. <xs:simpleType name="refQueryObjectNameIndexType">
  153. <xs:restriction base="resultSetRecordColumnIndexType"/>
  154. </xs:simpleType>
  155. <xs:simpleType name="refColumnNameIndexType">
  156. <xs:restriction base="resultSetRecordColumnIndexType"/>
  157. </xs:simpleType>
  158. <xs:simpleType name="refColumnSequenceIndexType">
  159. <xs:restriction base="resultSetRecordColumnIndexType"/>
  160. </xs:simpleType>
  161. <xs:simpleType name="refKeyNameIndexType">
  162. <xs:restriction base="resultSetRecordColumnIndexType"/>
  163. </xs:simpleType>
  164. <xs:group name="schemaGrainFilterableSql">
  165. <xs:sequence>
  166. <xs:element name="schemaGrainObjectSelectionsInclusion" minOccurs="0" maxOccurs="unbounded">
  167. <xs:complexType>
  168. <xs:sequence>
  169. <xs:element name="schemaGrainSelectionsCondition" maxOccurs="unbounded">
  170. <xs:complexType>
  171. <xs:attribute name="objectExpression"/>
  172. </xs:complexType>
  173. </xs:element>
  174. </xs:sequence>
  175. <xs:attribute name="sqlFragment" type="xs:string" use="required"/>
  176. <xs:attribute name="insertLocation" use="required">
  177. <xs:simpleType>
  178. <xs:restriction base="xs:NMTOKEN">
  179. <xs:enumeration value="before"/>
  180. <xs:enumeration value="after"/>
  181. </xs:restriction>
  182. </xs:simpleType>
  183. </xs:attribute>
  184. <xs:attribute name="insertPrefix" use="required">
  185. <xs:simpleType>
  186. <xs:restriction base="xs:NMTOKEN">
  187. <xs:enumeration value="WHERE"/>
  188. <xs:enumeration value="AND"/>
  189. </xs:restriction>
  190. </xs:simpleType>
  191. </xs:attribute>
  192. </xs:complexType>
  193. </xs:element>
  194. </xs:sequence>
  195. </xs:group>
  196. <xs:group name="objectGrainSql">
  197. <xs:sequence>
  198. <xs:element name="objectGrainSql">
  199. <xs:annotation>
  200. <xs:documentation>MIXED CONTENT - The type of this element is THE SQL that will be run against the database; the child elements serve as placeholders within the sql.</xs:documentation>
  201. </xs:annotation>
  202. <xs:complexType mixed="true">
  203. <xs:sequence>
  204. <xs:element name="catalogSubstitution" minOccurs="0"/>
  205. <xs:element name="schemaSubstitution"/>
  206. <xs:element name="objectSubstitution"/>
  207. </xs:sequence>
  208. </xs:complexType>
  209. </xs:element>
  210. </xs:sequence>
  211. </xs:group>
  212. <xs:group name="databaseGrainFilterableSql">
  213. <xs:sequence>
  214. <xs:group ref="sql">
  215. <xs:annotation>
  216. <xs:documentation>sql that operates on a "per database" level.</xs:documentation>
  217. </xs:annotation>
  218. </xs:group>
  219. <xs:element name="objectSelectionsInclusion" minOccurs="0" maxOccurs="unbounded">
  220. <xs:annotation>
  221. <xs:documentation>Generrates additonal WHERE clause filter conditions to be injected into the SQL above, based on a set of "database object selections".</xs:documentation>
  222. </xs:annotation>
  223. <xs:complexType>
  224. <xs:sequence>
  225. <xs:element name="objectSelectionsCondition" maxOccurs="unbounded">
  226. <xs:complexType>
  227. <xs:attribute name="catalogExpression"/>
  228. <xs:attribute name="schemaExpression"/>
  229. <xs:attribute name="objectExpression"/>
  230. </xs:complexType>
  231. </xs:element>
  232. </xs:sequence>
  233. <xs:attribute name="sqlFragment" type="xs:string" use="required"/>
  234. <xs:attributeGroup ref="whereClauseConditionInsertion"/>
  235. </xs:complexType>
  236. </xs:element>
  237. </xs:sequence>
  238. </xs:group>
  239. <xs:group name="sql">
  240. <xs:choice>
  241. <xs:element name="sql" type="xs:string"/>
  242. </xs:choice>
  243. </xs:group>
  244. <xs:group name="catalogGrainSql">
  245. <xs:sequence>
  246. <xs:element name="catalogGrainSql">
  247. <xs:annotation>
  248. <xs:documentation>MIXED CONTENT - The value of this element will appear as a piece of sql with the child substitution elements inside it.</xs:documentation>
  249. </xs:annotation>
  250. <xs:complexType mixed="true">
  251. <xs:sequence>
  252. <xs:element name="catalogSubstitution" minOccurs="0" maxOccurs="unbounded"/>
  253. </xs:sequence>
  254. </xs:complexType>
  255. </xs:element>
  256. </xs:sequence>
  257. </xs:group>
  258. <xs:attributeGroup name="parentSchemaRecordIndexMappings">
  259. <xs:attribute name="parentCatalog" type="resultSetRecordColumnIndexType" default="1"/>
  260. <xs:attribute name="parentSchema" type="resultSetRecordColumnIndexType" default="2"/>
  261. </xs:attributeGroup>
  262. <xs:group name="schemaGrainSql">
  263. <xs:choice>
  264. <xs:element name="schemaGrainSql" minOccurs="0">
  265. <xs:annotation>
  266. <xs:documentation>MIXED CONTENT - The value of this element will appear as a piece of sql with the child substitution elements inside it.</xs:documentation>
  267. </xs:annotation>
  268. <xs:complexType mixed="true">
  269. <xs:sequence>
  270. <xs:element name="catalogSubstitution" minOccurs="0"/>
  271. <xs:element name="schemaSubstitution" minOccurs="0" maxOccurs="unbounded"/>
  272. </xs:sequence>
  273. </xs:complexType>
  274. </xs:element>
  275. </xs:choice>
  276. </xs:group>
  277. <xs:group name="genericResultSetProvider">
  278. <xs:choice>
  279. <xs:element name="java">
  280. <xs:complexType>
  281. <xs:attribute name="className" use="required"/>
  282. </xs:complexType>
  283. </xs:element>
  284. <xs:element name="storedProcedureCall">
  285. <xs:complexType>
  286. <xs:sequence>
  287. <xs:element name="inputParam" minOccurs="0" maxOccurs="unbounded"/>
  288. </xs:sequence>
  289. </xs:complexType>
  290. </xs:element>
  291. <xs:element name="udaApiCall">
  292. <xs:complexType>
  293. <xs:sequence>
  294. <xs:element name="inputParam" minOccurs="0" maxOccurs="unbounded"/>
  295. </xs:sequence>
  296. </xs:complexType>
  297. </xs:element>
  298. </xs:choice>
  299. </xs:group>
  300. <xs:attributeGroup name="sqlFilterConditionInjection">
  301. <xs:attribute name="sqlFragment" type="xs:string" use="required"/>
  302. <xs:attribute name="insertLocation" use="required">
  303. <xs:simpleType>
  304. <xs:restriction base="xs:NMTOKEN">
  305. <xs:enumeration value="before"/>
  306. <xs:enumeration value="after"/>
  307. </xs:restriction>
  308. </xs:simpleType>
  309. </xs:attribute>
  310. <xs:attribute name="insertPrefix" use="required">
  311. <xs:simpleType>
  312. <xs:restriction base="xs:NMTOKEN">
  313. <xs:enumeration value="WHERE"/>
  314. <xs:enumeration value="AND"/>
  315. </xs:restriction>
  316. </xs:simpleType>
  317. </xs:attribute>
  318. </xs:attributeGroup>
  319. <xs:group name="javaFunction">
  320. <xs:sequence>
  321. <xs:element name="javaClass">
  322. <xs:complexType>
  323. <xs:attribute name="qualifiedClassName" type="xs:string" use="required"/>
  324. </xs:complexType>
  325. </xs:element>
  326. </xs:sequence>
  327. </xs:group>
  328. <xs:group name="sqlAccess">
  329. <xs:sequence>
  330. <xs:choice>
  331. <xs:group ref="objectGrainSql"/>
  332. <xs:group ref="schemaGrainSql"/>
  333. <xs:group ref="catalogGrainSql"/>
  334. <xs:group ref="sql"/>
  335. </xs:choice>
  336. <xs:sequence>
  337. <xs:element name="objectSelectionsInclusion" minOccurs="0" maxOccurs="unbounded">
  338. <xs:annotation>
  339. <xs:documentation>Generrates additonal WHERE clause filter conditions to be injected into the SQL above, based on a set of "database object selections".</xs:documentation>
  340. </xs:annotation>
  341. <xs:complexType>
  342. <xs:sequence>
  343. <xs:element name="objectSelectionsCondition" maxOccurs="unbounded">
  344. <xs:complexType>
  345. <xs:attribute name="catalogExpression"/>
  346. <xs:attribute name="schemaExpression"/>
  347. <xs:attribute name="objectExpression"/>
  348. <xs:attribute name="columnExpression"/>
  349. </xs:complexType>
  350. </xs:element>
  351. </xs:sequence>
  352. <xs:attribute name="sqlFragment" type="xs:string" use="required"/>
  353. <xs:attributeGroup ref="whereClauseConditionInsertion"/>
  354. </xs:complexType>
  355. </xs:element>
  356. </xs:sequence>
  357. </xs:sequence>
  358. </xs:group>
  359. </xs:schema>