SQLServerException: инструкция не возвращает результирующий набор при выполнении SQL

Я использую использование sqljdbc4.jar (sqljdbc_2.0) версия.

Я выполняю insert + a select back, чтобы получить идентификатор следующим образом:

BEGIN 
INSERT INTO DateRangeOptions (Description,Code) 
VALUES ('dateRange.quickPick.option.all','ALL');  
SELECT SCOPE_IDENTITY()  
END

а я:

com.microsoft.sqlserver.jdbc.SQLServerException: The statement did not return a result set.

строка:

st.executeQuery(updateQuery)

какие идеи?

3 ответов


обновлен с SQL 2000 до SQL 2005 и переключился на драйвер JDBC Microsoft SQL Server 2005 версии 1.2. Я получил ошибку "оператор не вернул результат"при выполнении вставки с последующим выбором SCOPE_IDENTITY ()".Я решил проблему с помощью executeUpdate () и getGeneratedKeys вместо executeQuery. Вот код до и после.

Примечание: соединение, используемое в этом примере, - java.язык SQL.связь не com.Microsoft.от SQLServer.интерфейс jdbc.SqlServerConnection.

код SQL 2000

String  dbURL = "jdbc:sqlserver" + "://" + dbServer + ":" +
                 dbServerPort + ";SelectedMethod=cursor;databaseName="
                           + dbName + ";user=xxx;password=xxx";
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
java.sql.Connection connection = DriverManager.getConnection(dbURL);
sql = "insert into Contact (name) values ('ABC'); SELECT SCOPE_IDENTITY()";
PreparedStatement ps = connection.prepareStatement(sql);
ResultSet rs = ps.executeQuery();
if (rs.next()) {
     long id = rs.getLong(1);
     System.out.println("Id=" + id);
}

код SQL 2005

String  dbURL = "jdbc:sqlserver" + "://" + dbServer + ":" +
                 dbServerPort + ";SelectedMethod=cursor;databaseName="
                           + dbName + ";user=xxx;password=xxx";

Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
java.sql.Connection connection = DriverManager.getConnection(dbURL);
sql = "insert into Contact (name) values ('ABC'); SELECT SCOPE_IDENTITY()";
PreparedStatement ps = connection.prepareStatement(sql);
ps.executeUpdate();  // do not use execute() here otherwise you may get the error
                     // The statement must be executed before 
                     // any results can be obtained on the next
                     // getGeneratedKeys statement.

ResultSet rs = ps.getGeneratedKeys();
if (rs.next()) {
     long id = rs.getLong(1);
     System.out.println("Id=" + id);
}

строка, которую вы вставили, не удалась, поэтому нет идентификатора ? задать запрос точки останова генерируется в Java скопируйте строку запроса и запустите ее в management studio, чтобы увидеть результат. Это может показать вам, что вы делаете неправильно.


любой вариант для обновления драйвера? Тогда вы можете просто использовать Statement#getGeneratedKeys(). Также смотрите эту статью:http://msdn.microsoft.com/en-us/library/ms378445%28SQL.90%29.aspx

Если это не вариант, то нужно уволить INSERT и SELECT отдельно друг за другом в том же соединении.