你目前正处于脱机状态,正在等待 Internet 重新连接

你的浏览器不受支持

你需要更新你的浏览器才能使用该网站。

更新到 Internet Explorer 的最新版本

PRB:在手工事务模式下无法启动克隆的连接

不再更新的 KB 内容免责声明
本文介绍那些 Microsoft 不再提供支持的产品。因此本文按“原样”提供,并且不再更新。
症状
使用 Microsoft SQL Server 2000 JDBC 驱动程序时,您可能会遇到以下异常:
java.sql.SQLException:[Microsoft][SQLServer 2000 Driver for JDBC]Can't start a cloned connection while in manual transaction mode.
原因
在手工事务模式 (AutoCommit=false) 下,如果使用直接 (SelectMethod=direct) 模式,当您尝试对使用 JDBC 驱动程序的 SQL Server 数据库执行多个语句时,将会出现此问题。直接模式是该驱动程序的默认模式。
解决方案
当您使用手工事务模式时,必须将驱动程序的 SelectMethod 属性设置为 Cursor,或者确保您按照本文“更多信息”一节指定的方式在每个连接上只使用一个活动语句。
状态
这种现象是设计导致的。
更多信息

重现此问题的步骤

使用以下代码重现此错误:

注意:请参见代码中的注释,以获取解决此问题所需的代码更改信息。
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();		}	}}				
参考
有关克隆连接的更多信息,请参见 Microsoft SQL Server 2000 JDBC 驱动程序 HTML 帮助中的“连接字符串属性”部分或参见联机指南。有关使用该驱动程序的克隆连接的其他信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
313220 PRB:到 SQL Server JDBC 的意外连接
JDBC
属性

文章 ID:313181 - 上次审阅时间:11/25/2004 10:54:33 - 修订版本: 2.0

  • Microsoft SQL Server 2000 Driver for JDBC
  • kbprb KB313181
反馈