我需要一个工具来捕获数据,然后将其保存在excel文件中并生成用于数据库执行的sql。
为了解决这个问题,我开始设计和开发一个框架,该框架将读取xml文件并呈现用于数据捕获的swing屏幕并将其保存在excel中。现在,我已经达到了我在excel中获取数据的阶段。现在,我无法进一步决定方法。我有一个方法来从excel表获取数据并构建sql,但我对这种方法没有信心。
我想到的方法是开发更多xml(db中的每个Schema一个),它将包含所需数据库表结构的副本。在GUI xml中,我将提供一个名为“databaseMapping”的新标记,其中包含SCHEMA_NAME; TABLE_NAME; COLUMN_NAME。当用户请求为特定文件生成sql时,我会读取与该excel相关的屏幕xml,找出数据库映射,然后构建sql。但我看到这种方法面临挑战: -
1)在excel中,列对应于多个表,并且可能将列分散在不同的表中,因此读取和构建sql将是消耗资源的活动。
2)阅读excel本身是如此之慢(使用POI),因此应用程序的性能会随着excel的增长而下降。我相信POI不支持从不同的工作表中处理整个列并构建新的工作簿或工作表?如果可以做到那么它仍然是可管理的。读取每一行然后每个单元格在db表结构中构建新的临时工作表以生成sql,对我来说似乎不太合适。
GUI XML
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<DataDetails>
<Page pageId="1">
<Column columnName="Branch ID">
<dataType>String</dataType>
<maxLength>3</maxLength>
<isMandatory>true</isMandatory>
<isUnique>true</isUnique>
<defaultValue></defaultValue>
<forbiddenCharacters></forbiddenCharacters>
<limitedChoices></limitedChoices>
<databaseMapping></databaseMapping>
</Column>
<Column columnName="Branch Name">
<dataType>String</dataType>
<maxLength>10</maxLength>
<isMandatory>false</isMandatory>
<isUnique>true</isUnique>
<defaultValue></defaultValue>
<forbiddenCharacters></forbiddenCharacters>
<limitedChoices></limitedChoices>
<databaseMapping></databaseMapping>
</Column>
<Column columnName="Branch Type">
<dataType>String</dataType>
<maxLength>15</maxLength>
<isMandatory>false</isMandatory>
<isUnique>true</isUnique>
<defaultValue></defaultValue>
<forbiddenCharacters></forbiddenCharacters>
<limitedChoices></limitedChoices>
<databaseMapping></databaseMapping>
</Column>
<Column columnName="Location">
<dataType>String</dataType>
<maxLength>3</maxLength>
<isMandatory>false</isMandatory>
<isUnique>true</isUnique>
<defaultValue></defaultValue>
<forbiddenCharacters></forbiddenCharacters>
<limitedChoices></limitedChoices>
<databaseMapping></databaseMapping>
</Column>
<Column columnName="Pincode">
<dataType>String</dataType>
<maxLength>3</maxLength>
<isMandatory>false</isMandatory>
<isUnique>true</isUnique>
<defaultValue></defaultValue>
<forbiddenCharacters></forbiddenCharacters>
<limitedChoices></limitedChoices>
<databaseMapping></databaseMapping>
</Column>
</Page>
<Page pageId="2">
<Column columnName="Business Line">
<dataType>String</dataType>
<maxLength>3</maxLength>
<isMandatory>false</isMandatory>
<isUnique>true</isUnique>
<defaultValue></defaultValue>
<forbiddenCharacters></forbiddenCharacters>
<limitedChoices></limitedChoices>
<databaseMapping></databaseMapping>
</Column>
<Column columnName="Branch Currency">
<dataType>Date</dataType>
<maxLength></maxLength>
<isMandatory>false</isMandatory>
<isUnique></isUnique>
<defaultValue></defaultValue>
<forbiddenCharacters></forbiddenCharacters>
<limitedChoices></limitedChoices>
<databaseMapping></databaseMapping>
</Column>
<Column columnName="Action">
<dataType>String</dataType>
<maxLength>10</maxLength>
<isMandatory>false</isMandatory>
<isUnique>true</isUnique>
<defaultValue></defaultValue>
<forbiddenCharacters></forbiddenCharacters>
<limitedChoices>ComboBoxTest_Single.xlsx - ACTION;ACTION </limitedChoices>
<headerName>CODE_SUB_ID</headerName>
<databaseMapping></databaseMapping>
</Column>
</Page>
</DataDetails>
DB XML(建议)
<?xml version="1.0" encoding="UTF-8"?>
<table name="tablename">
<column name="column1">
<dataType>varchar</dataType>
<length>20</length>
<nullAllowed>Y</nullAllowed>
<defaultValue></defaultValue>
<isPrimaryKey>Y</isPrimaryKey>
</column>
<column name="column2">
<dataType>timestamp</dataType>
<length></length>
<nullAllowed>Y</nullAllowed>
<defaultValue></defaultValue>
</column>
<column name="column3">
<dataType>varchar</dataType>
<length>20</length>
<nullAllowed>Y</nullAllowed>
<defaultValue></defaultValue>
</column>
<column name="column4">
<dataType>decimal</dataType>
<lengthIntegerPart>24</lengthIntegerPart>
<lengthFractionalPart>6</lengthFractionalPart>
<nullAllowed>Y</nullAllowed>
<defaultValue></defaultValue>
</column>
<column name="column5">
<dataType>integer</dataType>
<length>1</length>
<nullAllowed>Y</nullAllowed>
<defaultValue></defaultValue>
</column>
<column name="column6">
<dataType>varchar2</dataType>
<length>30</length>
<nullAllowed>N</nullAllowed>
<defaultValue></defaultValue>
</column>
<column name="column7">
<dataType>date</dataType>
<length></length>
<nullAllowed>Y</nullAllowed>
<defaultValue></defaultValue>
</column>
<column name="column8">
<dataType>decimal</dataType>
<lengthIntegerPart>24</lengthIntegerPart>
<lengthFractionalPart>6</lengthFractionalPart>
<nullAllowed>N</nullAllowed>
<defaultValue></defaultValue>
</column>
</table>
谢谢!
答案 0 :(得分:1)
我选择embedded database,例如H2,并同步旅行用户&#39;他们回家后的变化。
如果您采用您提出的方法,您可以利用这个Database Schema Definition Language(DBSDL)使用&#34; XSLT以SQL语句的形式生成DDL。&#34;