Phing:无效数据库连接详细信息后重新启动

问题描述 投票:1回答:1

我正在编写一个需要使用用户提供的详细信息连接到数据库的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>
phing
1个回答
0
投票

你可以使用<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>
© www.soinside.com 2019 - 2024. All rights reserved.