Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

SQLServerException :l'instruction n'a pas renvoyé de jeu de résultats lors de l'exécution de SQL

Mise à niveau de SQL 2000 vers SQL 2005 et passage à Microsoft SQL Server 2005 JDBC Driver version 1.2. J'ai eu l'erreur "L'instruction n'a pas renvoyé de résultat" lors de l'exécution d'une insertion suivie de SELECT SCOPE_IDENTITY()". J'ai résolu le problème en utilisant executeUpdate() et getGeneratedKeys au lieu d'executeQuery. Voici le code avant et après.

Remarque :La connexion utilisée dans cet exemple est java.sql.connection et non com.microsoft.sqlserver.jdbc.SqlServerConnection.

Code 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);
}

Code 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);
}