我正在编写一个需要使用用户提供的详细信息连接到数据库的Phing任务。
我能够提示用户输入主机/用户/密码/数据库,并使用PDOSQLExecTask测试详细信息。
我不知道该怎么做是重新提示用户重新提供细节,如果发现它们无效,并继续重新提示,直到他们做对。
下面的块是我的尝试,但它错误,因为Phing不喜欢任务调用自己。
<target name="prompt-and-test-database-connection">
<trycatch>
<try>
<input propertyName="db.host" message="Database host" promptChar=":" />
<input propertyName="db.user" message="Database user" promptChar=":" />
<input propertyName="db.pass" message="Database password" promptChar=":" />
<input propertyName="db.name" message="Database name" promptChar=":" />
<echo message="Testing connection..." />
<pdosqlexec url="mysql:host=${db.host};dbname=${db.name}" userid="${db.user}" password="${db.pass}" onerror="continue">
USE `${db.name}`;
</pdosqlexec>
</try>
<catch>
<echo level="error">Invalid database connection details. Please try again.</echo>
<phingcall target="prompt-and-test-database-connection" />
</catch>
</trycatch>
</target>
你可以使用<retry>
任务。由于<retry>
只接受一个嵌套任务,因此我在另一个任务中提取了连接。以下适用于我:
<target name="try-connection">
<retry retryCount="3">
<phingcall target="connection"/>
</retry>
</target>
<target name="connection">
<input propertyName="db.host" message="Database host" promptChar=":"/>
<input propertyName="db.user" message="Database user" promptChar=":"/>
<input propertyName="db.pass" message="Database password" promptChar=":"/>
<input propertyName="db.name" message="Database name" promptChar=":"/>
<echo message="Testing connection..."/>
<pdosqlexec url="mysql:host=${db.host};dbname=${db.name}"
userid="${db.user}"
password="${db.pass}"
onerror="continue">
USE `${db.name}`;
</pdosqlexec>
</target>