Oracle - скопировать таблицу из одной схемы в другую, используя ant - PullRequest
0 голосов
/ 16 ноября 2018

Мне нужно скопировать таблицу из одной схемы Oracle в другую, я могу сделать это, выполнив следующий запрос в schema_one -

create table EMPLOYEES unrecoverable as select * from schema_two.EMPLOYEES;

, который работает при запуске с использованием командной строки или разработчика SQL.

Но задача состоит в том, чтобы выполнить это, используя скрипт ant.

У меня есть цель муравья, как показано ниже

<target name="create.tables">
        <echo message="creating tables... " />
        <sql driver="${db.driver}"  
             url="${db.url}"
             userid="${db.username}"
             password="${db.password}"
             onerror="abort"
             keepformat="yes"
             encoding="UTF-8"
            >
            <transaction>
                create table EMPLOYEES unrecoverable as select * from schema_two.EMPLOYEES;

            </transaction>
            <classpath>
                <path refid="database.common.classpath"/>
            </classpath>
        </sql>
    </target>

, где db.driver, db.url, db.username и db.password определены для schema_one.Выполнение этого приводит к ошибке, как показано ниже:

У меня есть запись в tnsnames.ora также для схем.

java.sql.SQLRecoverableException: Listener refused the connection with the following error:
ORA-12514, TNS:listener does not currently know of service requested in connect descriptor

        at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:825)
        at oracle.jdbc.driver.PhysicalConnection.connect(PhysicalConnection.java:751)
        at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:38)
        at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:593)
        at org.apache.tools.ant.taskdefs.JDBCTask.getConnection(JDBCTask.java:366)
        at org.apache.tools.ant.taskdefs.SQLExec.getConnection(SQLExec.java:963)
        at org.apache.tools.ant.taskdefs.SQLExec.execute(SQLExec.java:628)
        at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:293)
        at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
        at org.apache.tools.ant.Task.perform(Task.java:348)
        at org.apache.tools.ant.Target.execute(Target.java:435)
        at org.apache.tools.ant.Target.performTasks(Target.java:456)
        at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1405)
        at org.apache.tools.ant.Project.executeTarget(Project.java:1376)
        at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
        at org.apache.tools.ant.Project.executeTargets(Project.java:1260)
        at org.apache.tools.ant.Main.runBuild(Main.java:857)
        at org.apache.tools.ant.Main.startAnt(Main.java:236)
        at org.apache.tools.ant.launch.Launcher.run(Launcher.java:287)
        at org.apache.tools.ant.launch.Launcher.main(Launcher.java:113)
Caused by: oracle.net.ns.NetException: Listener refused the connection with the following error:
ORA-12514, TNS:listener does not currently know of service requested in connect descriptor

        at oracle.net.ns.NSProtocolStream.negotiateConnection(NSProtocolStream.java:324)
        at oracle.net.ns.NSProtocol.connect(NSProtocol.java:287)
        at oracle.jdbc.driver.T4CConnection.connect(T4CConnection.java:1963)
        at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:564)
        ... 22 more
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...