gpt4 book ai didi

xml - Ant:我可以从 xml 文件中获取特定属性吗?

转载 作者:数据小太阳 更新时间:2023-10-29 02:32:13 24 4
gpt4 key购买 nike

我使用 ant 安装服务器进行测试。在属性文件中,我有一个数据库参数列表。问题是我需要在更改数据库时更改 5-6 个参数。其中大部分取决于数据库名称。所以我想我用我们使用的所有不同数据库创建一个 xml 文件,然后在属性文件中输入名称。然后,当构建文件运行时,它会获得所用数据库的正确属性。我创建了一个这样的 xml 文件:

<databases>
<database>
<server>mssql_1</server>
<port>1433</port>
<sid_instance>foobar</sid_instance>
<path></path>
<hostuser>sa</hostuser>
<hostpwd>password</hostpwd>
</database>
<database>
<server>oracle_1</server>
<port>1521</port>
<sid_instance>foobar</sid_instance>
<path>C:\\oracle\\oradata\\foobar</path>
<hostuser>system</hostuser>
<hostpwd>password</hostpwd>
</database>
</databases>

我在我的构建文件中调用该文件:

<xmlproperty file="databases.xml"  />

因此,当我的属性文件声明要使用“mssql_1”时,我希望加载匹配的属性。

但无论我如何尝试选择正确的数据,当我尝试使用

<echo message="${databases.database.port}">

我已经搜索了不同的方法来做到这一点,但我找不到方法来做到这一点。但它似乎应该是一件容易做的事......

最佳答案

您的属性文件有两个具有相同值的实体。 <xmlproperty>任务读取整个 XML 文件,然后使用实体设置属性名称。如果您碰巧有两个具有相同属性的实体,则该特定属性的值将是它们的总和。

大多数人所做的是为每个数据库创建一个单独的属性文件,然后使用 <property>任务 file读取该特定属性文件的参数。所以你应该有两个属性文件:

数据库.mssql.properties

server=mssql_1
port=1433
sid_instance=foobar
path=
hostuser=sa
hostpwd=password

数据库.oracle.properties

server=oracle_1
port=1521
sid_instance=foobar
path=C:/oracle/oradata/foobar
hostuser=ssytem
hostpwd=password

然后,在您的 build.xml 中文件,你只读入一个基于数据库的属性文件:

<property name="database"  value="mssql"/>   <!-- Default database -->
<property name="database.file value="database.${database}.properties"/>

<fail message="No such database file &quot;${database.file}&quot;">
<condition>
<not>
<available file="${database.file} type="file"/>
</not>
</condition>
</fail>

<property file="${database.file}"/>

当有人运行 Ant 时,他们可以使用 -D设置数据库的参数:

$ ant -Ddatabase=oracle

这将覆盖 database build.xml 内的属性(property)文件并使用 Oracle 数据库。如果您不指定数据库,它将使用默认数据库(MS SQL 数据库)。

而且,如果另一个属性文件指定了属性文件名,这也将起作用:

<property file="build.properties"> <!-- Contains database name -->
<property name="database.file" value="database.${database}.properties"/>

关于xml - Ant:我可以从 xml 文件中获取特定属性吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5936083/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com