Scriptella-SQLServerException:为更新生成了结果集

问题描述

我是Scriptella的初次用户,并且真的很难入门。

我似乎在sql Server 2012和MysqL上都遇到了相同的问题。两者都可以创建表和INSERT记录,但是在使用SELECT语句时出现以下错误

使用驱动程序mssql-jdbc-8.4.0.jre8.jar(及更低版本)的sql Server:
驱动程序异常:com.microsoft.sqlserver.jdbc.sqlServerException:生成了要更新的结果集。

使用驱动程序mysql-connector-java-5.1.45.jar的MysqL: 驱动程序异常:java.sql.sqlException:无法通过executeUpdate()或executeLargeUpdate()发出SELECT。

我无法确定这是脚本问题还是服务器配置问题。我试图在sql Server上设置nocount或nocount off,但是无济于事。

我尝试了Scriptella 1.1版和1.2版,并且存在相同的问题。

我对这个问题非常执着,以至于在关注stackoverflow.com数年之后,我终于在这里发布了我的第一个问题。非常感谢您的帮助。

请参阅以下有关我正在使用的脚本以及stacktrace的信息。谢谢。

<!DOCTYPE etl SYstem "http://scriptella.org/dtd/etl.dtd">
<etl>
    <properties>
        <include href="etl.properties"/> <!--Load from external properties file-->
    </properties>

    <!-- Connection declarations -->
    <connection driver="$driver" url="$url" user="$user" password="$password" classpath="$classpath"/>

    <!--ETL Queries and Scripts -->
    <script>
        <!-- CREATE TABLE WORKED!
          create table TestDB.dbo.test (
          id int
        );   -->

    <!-- INSERT WORKED!
      insert into TestDB.dbo.test (id) values (1);
    -->

    <!-- BELOW FAILS -->
        select * from TestDB.dbo.GLAccounts
        <script>
          insert into TestDB.dbo.test (id) values (?1);
        </script>
    </script>
</etl>

    etl-scriptsS   java -jar ~/Downloads/scriptella/scriptella-1.1/scriptella.jar my-first-etl.xml
    Aug 12,2020 8:11:33 AM <WARNING> XML configuration warning in file:/home/user1/workspace/etl-scripts/my-first-etl.xml(28:14): The content of element type "script" must match "(include|dialect|onerror)".
    Aug 12,2020 8:11:33 AM <INFO> Execution Progress.Initializing properties: 1%
    Aug 12,2020 8:11:36 AM com.microsoft.sqlserver.jdbc.TDSChannel enableSSL
    WARNING: TLSv1 was negotiated. Please update server and client to use TLSv1.2 at minimum.
    Aug 12,2020 8:11:36 AM <INFO> Execution Progress.Initialized connection JdbcConnection{com.microsoft.sqlserver.jdbc.sqlServerConnection},Dialect{Microsoft sql Server 11.00.2218},properties {}: 5%
    Aug 12,2020 8:11:36 AM <INFO> Execution Progress./etl/script[1] prepared: 10%
    Aug 12,2020 8:11:36 AM <INFO> Registered JMX mbean: scriptella:type=etl,url="file:/home/user1/workspace/etl-scripts/my-first-etl.xml"
    Aug 12,2020 8:11:36 AM <SEVERE> Script /home/user1/workspace/etl-scripts/my-first-etl.xml execution Failed.
    Location: /etl/script[1]
    JDBC provider exception: Unable to execute statement
    Error statement: 
    select * from TestDB.dbo.GLAccounts
    Error codes: [null,0]
    Driver exception: com.microsoft.sqlserver.jdbc.sqlServerException: A result set was generated for update.
    etl-scriptsS   java -jar ~/Downloads/scriptella/scriptella-1.1/scriptella.jar my-first-etl.xml
    Aug 12,2020 8:20:19 AM <WARNING> XML configuration warning in file:/home/user1/workspace/etl-scripts/my-first-etl.xml(28:14): The content of element type "script" must match "(include|dialect|onerror)".
    Aug 12,2020 8:20:19 AM <INFO> Execution Progress.Initializing properties: 1%
    Aug 12,2020 8:20:21 AM com.microsoft.sqlserver.jdbc.TDSChannel enableSSL
    WARNING: TLSv1 was negotiated. Please update server and client to use TLSv1.2 at minimum.
    Aug 12,2020 8:20:22 AM <INFO> Execution Progress.Initialized connection JdbcConnection{com.microsoft.sqlserver.jdbc.sqlServerConnection},2020 8:20:22 AM <INFO> Execution Progress./etl/script[1] prepared: 10%
    Aug 12,2020 8:20:22 AM <INFO> Registered JMX mbean: scriptella:type=etl,2020 8:20:22 AM <SEVERE> Script /home/user1/workspace/etl-scripts/my-first-etl.xml execution Failed.
    Location: /etl/script[1]
    JDBC provider exception: Unable to execute statement
    Error statement: 
    select * from TestDB.dbo.GLAccounts
    Error codes: [null,0]
    Driver exception: com.microsoft.sqlserver.jdbc.sqlServerException: A result set was generated for update.
    etl-scriptsS    java -jar ~/Downloads/scriptella/scriptella-1.1/scriptella.jar -debug my-first-etl.xml
    Aug 12,2020 9:30:52 AM <WARNING> XML configuration warning in file:/home/user1/workspace/etl-scripts/my-first-etl.xml(28:14): The content of element type "script" must match "(include|dialect|onerror)".
    Aug 12,2020 9:30:52 AM <INFO> Execution Progress.Initializing properties: 1%
    Aug 12,2020 9:30:53 AM <FINE> registerDriver: sqlServerDriver:1
    Aug 12,2020 9:30:53 AM <FINE> Found driver class com.microsoft.sqlserver.jdbc.sqlServerDriver
    Aug 12,2020 9:30:53 AM <FINE> DriverManager.getConnection("jdbc:sqlserver://XXX.XXX.XXX.XXX:12345")
    Aug 12,2020 9:30:53 AM <FINE>     trying com.microsoft.sqlserver.jdbc.sqlServerDriver
    Aug 12,2020 9:30:54 AM com.microsoft.sqlserver.jdbc.TDSChannel enableSSL
    WARNING: TLSv1 was negotiated. Please update server and client to use TLSv1.2 at minimum.
    Aug 12,2020 9:30:54 AM <FINE> sqlWarning: reason(TLSv1 was negotiated. Please update server and client to use TLSv1.2 at minimum.)
    Aug 12,2020 9:30:54 AM <FINE> getConnection returning com.microsoft.sqlserver.jdbc.sqlServerDriver
    Aug 12,2020 9:30:54 AM <FINE> jdbc:sqlserver://XXX.XXX.XXX.XXX:12345: Statement cache is enabled (cache size 64). Statement separator ';'. Autocommit: false.
    Aug 12,2020 9:30:54 AM <INFO> Execution Progress.Initialized connection JdbcConnection{com.microsoft.sqlserver.jdbc.sqlServerConnection},2020 9:30:54 AM <INFO> Execution Progress./etl/script[1] prepared: 10%
    Aug 12,2020 9:30:54 AM <INFO> Registered JMX mbean: scriptella:type=etl,2020 9:30:54 AM <FINE> Executing script /etl/script[1]
    Aug 12,2020 9:30:55 AM <FINE> sqlState(null) vendor code(0)
    Aug 12,2020 9:30:55 AM <FINE> Rolling back JdbcConnection{com.microsoft.sqlserver.jdbc.sqlServerConnection}
    Aug 12,2020 9:30:55 AM <FINE> Closing JdbcConnection{com.microsoft.sqlserver.jdbc.sqlServerConnection}
    Aug 12,2020 9:30:55 AM <SEVERE> Script /home/user1/workspace/etl-scripts/my-first-etl.xml execution Failed.
    Location: /etl/script[1]
    JDBC provider exception: Unable to execute statement
    Error statement: 
    select * from TestDB.dbo.GLAccounts
    Error codes: [null,0]
    Driver exception: com.microsoft.sqlserver.jdbc.sqlServerException: A result set was generated for update.
    ---------------Debug Stack Trace-----------------
    scriptella.core.ExceptionInterceptor$ExecutionException: /etl/script[1] Failed: Unable to execute statement
        at scriptella.core.ExceptionInterceptor.execute(ExceptionInterceptor.java:44)
        at scriptella.core.Session.execute(Session.java:103)
        at scriptella.execution.EtlExecutor.execute(EtlExecutor.java:227)
        at scriptella.execution.EtlExecutor.execute(EtlExecutor.java:183)
        at scriptella.tools.launcher.EtlLauncher.execute(EtlLauncher.java:276)
        at scriptella.tools.launcher.EtlLauncher.launch(EtlLauncher.java:193)
        at scriptella.tools.launcher.EtlLauncher.main(EtlLauncher.java:321)
    Caused by: scriptella.jdbc.JdbcException: Unable to execute statement. Error statement: 
    select * from TestDB.dbo.GLAccounts. Error codes: [null,0]
        at scriptella.jdbc.sqlExecutor.statementParsed(sqlExecutor.java:140)
        at scriptella.jdbc.sqlParserBase.handleStatement(sqlParserBase.java:129)
        at scriptella.jdbc.sqlParserBase.parse(sqlParserBase.java:72)
        at scriptella.jdbc.sqlExecutor.execute(sqlExecutor.java:85)
        at scriptella.jdbc.sqlExecutor.execute(sqlExecutor.java:63)
        at scriptella.jdbc.JdbcConnection.executeScript(JdbcConnection.java:211)
        at scriptella.core.ScriptExecutor.execute(ScriptExecutor.java:49)
        at scriptella.core.ContentExecutor.execute(ContentExecutor.java:73)
        at scriptella.core.ElementInterceptor.executeNext(ElementInterceptor.java:56)
        at scriptella.core.StatisticInterceptor.execute(StatisticInterceptor.java:41)
        at scriptella.core.ElementInterceptor.executeNext(ElementInterceptor.java:56)
        at scriptella.core.ExceptionInterceptor.execute(ExceptionInterceptor.java:39)
        ... 6 more
    Caused by: com.microsoft.sqlserver.jdbc.sqlServerException: A result set was generated for update.
        at com.microsoft.sqlserver.jdbc.sqlServerException.makeFromDriverError(sqlServerException.java:234)
        at com.microsoft.sqlserver.jdbc.sqlServerStatement.doExecuteStatement(sqlServerStatement.java:886)
        at com.microsoft.sqlserver.jdbc.sqlServerStatement$StmtExecCmd.doExecute(sqlServerStatement.java:767)
        at com.microsoft.sqlserver.jdbc.TDSCommand.execute(IOBuffer.java:7375)
        at com.microsoft.sqlserver.jdbc.sqlServerConnection.executeCommand(sqlServerConnection.java:3200)
        at com.microsoft.sqlserver.jdbc.sqlServerStatement.executeCommand(sqlServerStatement.java:247)
        at com.microsoft.sqlserver.jdbc.sqlServerStatement.executeStatement(sqlServerStatement.java:222)
        at com.microsoft.sqlserver.jdbc.sqlServerStatement.executeUpdate(sqlServerStatement.java:710)
        at scriptella.jdbc.StatementWrapper$Simple.update(StatementWrapper.java:167)
        at scriptella.jdbc.sqlExecutor.statementParsed(sqlExecutor.java:130)
    ... 17 more

解决方法

问题出在我的脚本上。下面的更正脚本工作正常...

$fields = array(
        'app_id' => $this->api_key,'include_player_ids' => $devices,'data' => array(
            "type" => $type,"url" => $url
        ),'contents' => $content
    );

    if (null != $dateTime) {
        date_time_set($dateTime,9,0);

        array_push($fields,[
            'send_after' => $dateTime->format('Y-m-d H:i:s TO')] );
    }

    $fields = json_encode($fields);