高手在哪里?(数据库的连接) 高手在哪里?(VS 2005 的数据库的连接方法) 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 自己去www.connectionstrings.com查看 Connection类有四种:SqlConnection,OleDbConnection,OdbcConnection和OracleConnection。 SqlConnection类的对象连接SQL Server数据库;OracleConnection 类的对象连接Oracle数据库; OleDbConnection类的对象连接支持OLE DB的数据库,如Access;而OdbcConnection类的对象连接任何支持ODBC的数据库。与数据库的所有通讯最终都是通过Connection对象来完成的。 SqlConnection类 Connection 用于与数据库“对话”,并由特定提供程序的类(如 SqlConnection)表示。尽管SqlConnection类是针对Sql Server的,但是这个类的许多属性、方法与事件和OleDbConnection及OdbcConnection等类相似。本章将重点讲解SqlConnection特定的属性与方法,其他的Connection类你可以参考相应的帮助文档。 注意:使用不同的Connection对象需要导入不同的命名空间。OleDbConnection的命名空间为System.Data.OleDb。SqlConnection的命名空间为System.Data.SqlClient。OdbcConnection的命名空间为System.Data.Odbc。OracleConnection的命名空间为System.Data.OracleClinet。 SqlConnection属性: 属性说明 ConnectionString其返回类型为string,获取或设置用于打开 SQL Server 数据库的字符串。 ConnectionTimeOut 其返回类型为int,获取在尝试建立连接时终止尝试并生成错误之前所等待的时间。 Database其返回类型为string,获取当前数据库或连接打开后要使用的数据库的名称。 DataSource其返回类型为string,获取要连接的 SQL Server 实例的名称。 State其返回类型为ConnectionState,取得当前的连接状态:Broken、Closed、Connecting、Fetching或Open。 ServerVersion其返回类型为string,获取包含客户端连接的 SQL Server 实例的版本的字符串。 PacketSize获取用来与 SQL Server 的实例通信的网络数据包的大小(以字节为单位)。这个属性只适用于SqlConnection类型 SqlConnection方法: 方法说明 Close()其返回类型为void,关闭与数据库的连接。 CreateCommand() 其返回类型为SqlCommand,创建并返回一个与 SqlConnection 关联的SqlCommand 对象。 Open() 其返回类型为void,用连接字符串属性指定的属性打开数据库连接 SqlConnection事件: 事件说明 StateChange 当事件状态更改时发生。 (从 DbConnection 继承。) InfoMessage 当 SQL Server 返回一个警告或信息性消息时发生。 提示:可以用事件让一个对象以某种方式通知另一对象产生某些事情。例如我们在Windows系统中选择“开始”菜单,一旦单击鼠标时,就发生了一个事件,通知操作系统将“开始”菜单显示出来。 使用SqlConnection对象连接SQL Server数据库 我们可以用SqlConnection()构造函数生成一个新的SqlConnection对象。这个函数是重载的,即我们可以调用构造函数的不同版本。SqlConnection()的构造函数如下表所示: 构造函数说明 SqlConnection () 初始化 SqlConnection 类的新实例。 SqlConnection (String)如果给定包含连接字符串的字符串,则初始化 SqlConnection 类的新实例。 假设我们导入了System.Data.SqlClient命名空间,则可以用下列语句生成新的SqlConnection对象: SqlConnection mySqlConnection = new SqlConnection(); 程序代码说明:在上述语法范例的程序代码中,我们通过使用“new“关键字生成了一个新的SqlConnection对象,并且将其命名为mySqlConnection。 现在我们就可以使用如下两种方式连接数据库,即采用集成的Windows验证和使用Sql Server身份验证进行数据库的登录。 集成的Windows身份验证语法范例 string connectionString="server=localhost;database=Northwind; integrated security=SSPI"; 程序代码说明:在上述语法范例的程序代码中,我们设置了一个针对Sql Server数据库的连接字符串。其中server表示运行Sql Server的计算机名,由于在本书中,ASP.NET程序和数据库系统是位于同一台计算机的,所以我们可以用localhost取代当前的计算机名。database表示所使用的数据库名,这里设置为Sql Server自带的一个示例数据库--Northwind。由于我们希望采用集成的Windows验证方式,所以设置 integrated security为SSPI即可。 Sql Server 2005中的Windows身份验证模式如下: Sql Server 2005中的Windows身份验证 注意:在使用集成的Windows验证方式时,并不需要我们输入用户名和口令,而是把登录Windows时输入的用户名和口令传递到SqlServer。然后Sql Server检查用户清单,检查其是否具有访问数据库的权限。而且数据库连接字符串是不区分大小写的。 采用Sql Server身份验证的语法范例 string connectionString = "server=localhost;database=Northwind;uid=sa;pwd=sa"; 程序代码说明:在上述语法范例的程序代码中,采用了使用已知的用户名和密码验证进行数据库的登录。uid为指定的数据库用户名,pwd为指定的用户口令。为了安全起见,一般不要在代码中包括用户名和口令,你可以采用前面的集成的Windows验证方式或者对Web.Config文件中的连接字符串加密的方式提高程序的安全性。 Sql Server 2005中的Sql Server身份验证模式如下: Sql Server 2005中的Windows身份验证 如果你使用其他的数据提供者的话,所产生的连接字符串也具有相类似的形式。例如我们希望以OLE DB的方式连接到一个Oracle数据库,其连接字符串如下: string connectionString = "data source=localhost;initial catalog=Sales; use id=sa;password=;provider=MSDAORA"; 程序代码说明:在上述语法范例的程序代码中,通过专门针对Oracle数据库的OLE DB提供程序,实现数据库的连接。data source 表示运行Oracle数据库的计算机名,initial catalog表示所使用的数据库名。provider表示使用的OLE DB提供程序为MSDAORA。 Access数据库的连接字符串的形式如下: string connectionString = "provider=Microsoft.Jet.OLEDB.4.0; @”data source=c:\DataSource\Northwind.mdb”; 程序代码说明:在上述语法范例的程序代码中,通过专门针对Access数据库的OLE DB提供程序,实现数据库的连接。这使用的的OLE DB提供程序为Microsoft.Jet.OLEDB.4.0,并且数据库存放在c:\DataSource目录下,其数据库文件为Northwind.mdb。 现在我们就可以将数据库连接字符串传人SqlConnection()构造函数,例如: string connectionString = "server=localhost;database=Northwind;uid=sa;pwd=sa"; SqlConnection mySqlConnection = new SqlConnection(connectionString); 或者写成 SqlConnection mySqlConnection =new SqlConnection( "server=localhost;database=Northwind;uid=sa;pwd=sa"); 在前面的范例中,通过使用“new“关键字生成了一个新的SqlConnection对象。因此我们也可以设置该对象的ConnectionString属性,为其指定一个数据库连接字符串。这和将数据库连接字符串传人SqlConnection()构造函数的功能是一样的。 SqlConnection mySqlConnection = new SqlConnection(); mySqlConnection.ConnectionString = "server=localhost;database=Northwind;uid=sa;pwd=sa"; 注意:只能在关闭Connection对象时设置ConnectionString属性。 打开和关闭数据库连接 生成Connection对象并将其设置ConnectionString属性设置为数据库连接的相应细节之后,就可以打开数据库连接。为此可以调用Connection对象的Open()方法。其方法如下: mySqlConnection.Open(); 完成数据库的连接之后,我们可以调用Connection对象的Close()方法关闭数据库连接。例如: mySqlConnection.Close(); 关于"那么数据库连接字符串怎么改?我改来改去就是调试不好?"建议你看一下关于SQL Server的书. 这是为什么呢?paint为何不能实时变化? 短信转码的问题 如何把一个二进制数据放到DataTable中 Java 和 C# 冒泡排序 给写个!求解释 mysql 添加数据出错!!!!!! 请教在treeView中如何设置节点id号? 请教:从外网访问内网问题。 Combobox C#实现USB摄像头录像功能 DataSet的绑定问题2 WinForm查找控件是否存在 怎样把拖放DATAGRID中的一行数据到另一窗体中的DATAGRID中
www.connectionstrings.com
查看
DB的数据库,如Access;而OdbcConnection类的对象连接任何支持ODBC的数据库。与数据库的所有通讯最终都是通过Connection对象来完成的。
SqlConnection类 Connection 用于与数据库“对话”,并由特定提供程序的类(如
SqlConnection)表示。尽管SqlConnection类是针对Sql
Server的,但是这个类的许多属性、方法与事件和OleDbConnection及OdbcConnection等类相似。本章将重点讲解SqlConnection特定的属性与方法,其他的Connection类你可以参考相应的帮助文档。 注意:使用不同的Connection对象需要导入不同的命名空间。OleDbConnection的命名空间为System.Data.OleDb。SqlConnection的命名空间为System.Data.SqlClient。OdbcConnection的命名空间为System.Data.Odbc。OracleConnection的命名空间为System.Data.OracleClinet。 SqlConnection属性:
属性说明
ConnectionString其返回类型为string,获取或设置用于打开 SQL Server 数据库的字符串。
ConnectionTimeOut 其返回类型为int,获取在尝试建立连接时终止尝试并生成错误之前所等待的时间。
Database其返回类型为string,获取当前数据库或连接打开后要使用的数据库的名称。
DataSource其返回类型为string,获取要连接的 SQL Server 实例的名称。
State其返回类型为ConnectionState,取得当前的连接状态:Broken、Closed、Connecting、Fetching或Open。
ServerVersion其返回类型为string,获取包含客户端连接的 SQL Server 实例的版本的字符串。
PacketSize获取用来与 SQL Server
的实例通信的网络数据包的大小(以字节为单位)。这个属性只适用于SqlConnection类型
SqlConnection方法:
方法说明
Close()其返回类型为void,关闭与数据库的连接。
CreateCommand() 其返回类型为SqlCommand,创建并返回一个与 SqlConnection 关联的SqlCommand 对象。
Open() 其返回类型为void,用连接字符串属性指定的属性打开数据库连接 SqlConnection事件: 事件说明
StateChange 当事件状态更改时发生。 (从 DbConnection 继承。)
InfoMessage 当 SQL Server 返回一个警告或信息性消息时发生。 提示:可以用事件让一个对象以某种方式通知另一对象产生某些事情。例如我们在Windows系统中选择“开始”菜单,一旦单击鼠标时,就发生了一个事件,通知操作系统将“开始”菜单显示出来。 使用SqlConnection对象连接SQL Server数据库 我们可以用SqlConnection()构造函数生成一个新的SqlConnection对象。这个函数是重载的,即我们可以调用构造函数的不同版本。SqlConnection()的构造函数如下表所示:
构造函数说明
SqlConnection () 初始化 SqlConnection 类的新实例。
SqlConnection (String)如果给定包含连接字符串的字符串,则初始化 SqlConnection
类的新实例。
假设我们导入了System.Data.SqlClient命名空间,则可以用下列语句生成新的SqlConnection对象:
SqlConnection mySqlConnection = new SqlConnection();
程序代码说明:在上述语法范例的程序代码中,我们通过使用“new“关键字生成了一个新的SqlConnection对象,并且将其命名为mySqlConnection。
现在我们就可以使用如下两种方式连接数据库,即采用集成的Windows验证和使用Sql Server身份验证进行数据库的登录。 集成的Windows身份验证语法范例
string connectionString="server=localhost;database=Northwind;
integrated security=SSPI";
程序代码说明:在上述语法范例的程序代码中,我们设置了一个针对Sql Server数据库的连接字符串。其中server表示运行Sql
Server的计算机名,由于在本书中,ASP.NET程序和数据库系统是位于同一台计算机的,所以我们可以用localhost取代当前的计算机名。database表示所使用的数据库名,这里设置为Sql
Server自带的一个示例数据库--Northwind。由于我们希望采用集成的Windows验证方式,所以设置 integrated
security为SSPI即可。 Sql Server 2005中的Windows身份验证模式如下: Sql Server 2005中的Windows身份验证
注意:在使用集成的Windows验证方式时,并不需要我们输入用户名和口令,而是把登录Windows时输入的用户名和口令传递到SqlServer。然后Sql Server检查用户清单,检查其是否具有访问数据库的权限。而且数据库连接字符串是不区分大小写的。
采用Sql Server身份验证的语法范例 string connectionString =
"server=localhost;database=Northwind;uid=sa;pwd=sa"; 程序代码说明:在上述语法范例的程序代码中,采用了使用已知的用户名和密码验证进行数据库的登录。uid为指定的数据库用户名,pwd为指定的用户口令。为了安全起见,一般不要在代码中包括用户名和口令,你可以采用前面的集成的Windows验证方式或者对Web.Config文件中的连接字符串加密的方式提高程序的安全性。 Sql Server 2005中的Sql Server身份验证模式如下: Sql Server 2005中的Windows身份验证
如果你使用其他的数据提供者的话,所产生的连接字符串也具有相类似的形式。例如我们希望以OLE
DB的方式连接到一个Oracle数据库,其连接字符串如下:
string connectionString = "data source=localhost;initial
catalog=Sales;
use id=sa;password=;provider=MSDAORA"; 程序代码说明:在上述语法范例的程序代码中,通过专门针对Oracle数据库的OLE DB提供程序,实现数据库的连接。data
source 表示运行Oracle数据库的计算机名,initial catalog表示所使用的数据库名。provider表示使用的OLE
DB提供程序为MSDAORA。 Access数据库的连接字符串的形式如下:
string connectionString = "provider=Microsoft.Jet.OLEDB.4.0;
@”data source=c:\DataSource\Northwind.mdb”; 程序代码说明:在上述语法范例的程序代码中,通过专门针对Access数据库的OLE DB提供程序,实现数据库的连接。这使用的的OLE
DB提供程序为Microsoft.Jet.OLEDB.4.0,并且数据库存放在c:\DataSource目录下,其数据库文件为Northwind.mdb。 现在我们就可以将数据库连接字符串传人SqlConnection()构造函数,例如:
string connectionString =
"server=localhost;database=Northwind;uid=sa;pwd=sa";
SqlConnection mySqlConnection = new
SqlConnection(connectionString); 或者写成
SqlConnection mySqlConnection =new SqlConnection(
"server=localhost;database=Northwind;uid=sa;pwd=sa");
在前面的范例中,通过使用“new“关键字生成了一个新的SqlConnection对象。因此我们也可以设置该对象的ConnectionString属性,为其指定一个数据库连接字符串。这和将数据库连接字符串传人SqlConnection()构造函数的功能是一样的。
SqlConnection mySqlConnection = new SqlConnection();
mySqlConnection.ConnectionString =
"server=localhost;database=Northwind;uid=sa;pwd=sa";
注意:只能在关闭Connection对象时设置ConnectionString属性。
打开和关闭数据库连接 生成Connection对象并将其设置ConnectionString属性设置为数据库连接的相应细节之后,就可以打开数据库连接。为此可以调用Connection对象的Open()方法。其方法如下: mySqlConnection.Open(); 完成数据库的连接之后,我们可以调用Connection对象的Close()方法关闭数据库连接。例如: mySqlConnection.Close();
"那么数据库连接字符串怎么改?我改来改去就是调试不好?"
建议你看一下关于SQL Server的书.