PRB: Kann keine geklonte Verbindung beim im manuellen Transaktion-Modus gestartet.

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 313181 - Produkte anzeigen, auf die sich dieser Artikel bezieht
Alles erweitern | Alles schließen

Auf dieser Seite

Problembeschreibung

Microsoft SQL Server 2000-Treiber für JDBC verwenden, können die folgende Ausnahme auftreten:
java.SQL.SQLException: [Microsoft] [SQL Server 2000-Treiber für JDBC] kann nicht starten eine geklonte Verbindung im Modus manuelle Buchung.

Ursache

Dieser Fehler tritt beim Ausführen mehrerer Anweisungen in einer SQL Server-Datenbank mit dem JDBC-Treiber im Modus manuelle Buchung (AutoCommit = False) und die direkte Verwendung (SelectMethod = direkte) Modus. Direkten Modus ist der Standardmodus für den Treiber.

Lösung

Wenn Sie manuelle Transaktionsmodus verwenden, müssen Sie legen Sie die SelectMethod -Eigenschaft des Treibers auf Cursor oder stellen Sie sicher, dass Sie nur eine aktive Anweisung pro Verbindung wie angegeben im Abschnitt "Weitere Informationen" dieses Artikels verwenden.

Status

Es handelt sich hierbei um ein beabsichtigtes Verhalten.

Weitere Informationen

Schritte zum Reproduzieren des Verhaltens

Verwenden Sie den folgenden Code, um den Fehler zu reproduzieren:

Hinweis : die Kommentare im Code Informationen anzeigen, auf die Codeänderungen, die zur Behebung des Problems erforderlich sind.
import java.sql.*;
import java.io.*;


public class Repro{

	public static void main(String args[])
	{
		try {
			Connection con;
			Statement s1 = null;
			ResultSet r1 = null;
			Statement s2 = null;
			ResultSet r2 = null;
			Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver"); 
			con = DriverManager.getConnection(
				"jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs;SelectMethod=Direct;User=User;Password=Password");
			//fix 1
				//"jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs;SelectMethod=Cursor;User=User;Password=Password");
			con.setAutoCommit(false);
			
			try {
				s1 = con.createStatement();
				r1 = s1.executeQuery("SELECT * FROM authors");
				
				//fix 2
				//r1.close();
				//s1.close();

				s2 = con.createStatement();
				r2 = s2.executeQuery("SELECT * FROM publishers");
			}
			catch (SQLException ex)
			{
				System.out.println(ex);				
			}
		
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
	}
}
				

Informationsquellen

Weitere Informationen zu Verbindungen geklonter finden Sie für JDBC HTML-Hilfe oder der Onlinedokumentation im Abschnitt String Verbindungseigenschaften der Microsoft SQL Server 2000-Treiber.Weitere Informationen zu geklonte Verbindungen mit dem Treiber folgendem Artikel der Microsoft Knowledge Base:
313220PRB: Unerwarteter Verbindungen zu SQLServer mit JDBC

Eigenschaften

Artikel-ID: 313181 - Geändert am: Montag, 30. Juni 2003 - Version: 2.0
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft SQL Server 2000 Driver for JDBC
Keywords: 
kbmt kbprb KB313181 KbMtde
Maschinell übersetzter Artikel
Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.
Den englischen Originalartikel können Sie über folgenden Link abrufen: 313181
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.
Disclaimer zu nicht mehr gepflegten KB-Inhalten
Dieser Artikel wurde für Produkte verfasst, für die Microsoft keinen Support mehr anbietet. Der Artikel wird deshalb in der vorliegenden Form bereitgestellt und nicht mehr weiter aktualisiert.

Ihr Feedback an uns

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com