Sqlserver
 sql >> база данни >  >> RDS >> Sqlserver

SQLServerException:Изявлението не върна набор от резултати при изпълнение на SQL

Надстроен от SQL 2000 до SQL 2005 и премина към Microsoft SQL Server 2005 JDBC драйвер версия 1.2. Получих грешката „Изявлението не върна резултат“ при изпълнение на Insert, последвано от SELECT SCOPE_IDENTITY()“. Реших проблема с помощта на executeUpdate() и getGeneratedKeys вместо executeQuery. Ето кода преди и след.

Забележка:Връзката, използвана в този пример, е java.sql.connection, а не 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);
}


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Неклъстерният индекс в колона с клъстерен индекс подобрява производителността?

  2. Актуализиране на всички SQL NULL стойности в множество колони с помощта на клауза WHERE на ниво колона?

  3. Декларирайте променлива с множество стойности в SQL

  4. Променете формата на датата и часа по подразбиране в една база данни в SQL Server

  5. SQL формат за дата и час само до дата