2022年2022年连接SQLServer数据库详解 .pdf
《2022年2022年连接SQLServer数据库详解 .pdf》由会员分享,可在线阅读,更多相关《2022年2022年连接SQLServer数据库详解 .pdf(13页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、ASP.NET 连接 SQL Server 数据库详解本文将详细介绍如何使用Connection对象连接数据库。对于不同的.NET 数据提供者,ADO.NET采用不同的Connection对象连接数据库。这些Connection对象为我们屏蔽了具体的实现细节,并提供了一种统一的实现方法。Connection类有四种: SqlConnection,OleDbConnection ,OdbcConnection 和OracleConnection。SqlConnection类的对象连接SQL Server 数据库; OracleConnection 类的对象连接Oracle 数据库;OleDbCo
2、nnection 类的对象连接支持OLE DB的数据库,如Access;而 OdbcConnection类的对象连接任何支持ODBC 的数据库。与数据库的所有通讯最终都是通过Connection对象来完成的。SqlConnection类Connection 用于与数据库“对话”,并由特定提供程序的类(如 SqlConnection) 表示。尽管 SqlConnection类是针对Sql Server的,但是这个类的许多属性、方法与事件和OleDbConnection及 OdbcConnection 等类相似。 本章将重点讲解SqlConnection特定的属性与方法,其他的Connection
3、类你可以参考相应的帮助文档。注意: 使用不同的Connection对象需要导入不同的命名空间。OleDbConnection的命名空间为 System.Data.OleDb 。SqlConnection的命名空间为System.Data.SqlClient。OdbcConnection 的命名空间为System.Data.Odbc 。OracleConnection的命名空间为System.Data.OracleClinet。SqlConnection属性:属性说明ConnectionString 其返回类型为string,获取或设置用于打开 SQL Server 数据库的字符串。Connec
4、tionTimeOut 其返回类型为int,获取在尝试建立连接时终止尝试并生成错误之前所等待的时间。Database 其返回类型为string,获取当前数据库或连接打开后要使用的数据库的名名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 13 页 - - - - - - - - - 称。DataSource 其返回类型为string,获取要连接的 SQL Server 实例的名称。State 其返回类型为ConnectionState,取得当前的连接状态:Broken 、C
5、losed 、Connecting 、Fetching或 Open 。ServerVersion 其返回类型为string,获取包含客户端连接的 SQL Server 实例的版本的字符串。PacketSize 获取用来与 SQL Server 的实例通信的网络数据包的大小(以字节为单位)。这个属性只适用于SqlConnection类型SqlConnection方法:方法说明Close() 其返回类型为void, 关闭与数据库的连接。CreateCommand() 其返回类型为SqlCommand,创建并返回一个与 SqlConnection 关联的SqlCommand 对象。Open() 其返
6、回类型为void, 用连接字符串属性指定的属性打开数据库连接SqlConnection事件:事件说明StateChange 当事件状态更改时发生。(从 DbConnection 继承。)InfoMessage 当 SQL Server 返回一个警告或信息性消息时发生。提示:可以用事件让一个对象以某种方式通知另一对象产生某些事情。例如我们在Windows 系统中选择“开始”菜单,一旦单击鼠标时,就发生了一个事件,通知操作系统 将“开始”菜单显示出来。使用 SqlConnection对象连接SQL Server 数据库我们可以用SqlConnection()构造函数生成一个新的SqlConnect
7、ion对象。这个函数是重载的,即我们可以调用构造函数的不同版本。SqlConnection()的构造函数如下表所示:构造函数说明SqlConnection () 初始化 SqlConnection 类的新实例。SqlConnection (String) 如果给定包含连接字符串的字符串,则初始化 SqlConnection 类的新实例。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 13 页 - - - - - - - - - 假设我们导入了System.Data.Sql
8、Client命名空间,则可以用下列语句生成新的SqlConnection对象:SqlConnection mySqlConnection = new SqlConnection(); 程序代码说明: 在上述语法范例的程序代码中,我们通过使用“ new “关键字生成了一个新的 SqlConnection对象,并且将其命名为mySqlConnection 。现在我们就可以使用如下两种方式连接数据库,即采用集成的Windows验证和使用Sql Server 身份验证进行数据库的登录。集成的 Windows 身份验证语法范例string connectionString=server=localhos
9、t;database=Northwind; integrated security=SSPI; 程序代码说明: 在上述语法范例的程序代码中,我们设置了一个针对Sql Server 数据库的连接字符串。其中server表示运行 Sql Server的计算机名,由于在本书中,ASP.NET程序和数据库系统是位于同一台计算机的,所以我们可以用localhost取代当前的计算机名。database 表示所使用的数据库名,这里设置为Sql Server自带的一个示例数据库-Northwind。由于我们希望采用集成的Windows 验证方式, 所以设置 integrated security为 SSPI
10、即可。Sql Server 2005中的 Windows身份验证模式如下:名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 13 页 - - - - - - - - - 采用 Sql Server身份验证的语法范例string connectionString = server=localhost;database=Northwind;uid=sa;pwd=sa; 程序代码说明: 在上述语法范例的程序代码中,采用了使用已知的用户名和密码验证进行数据库的登录。uid 为指定的
11、数据库用户名,pwd为指定的用户口令。为了安全起见,一般不要在代码中包括用户名和口令,你可以采用前面的集成的Windows验证方式或者对Web.Config 文件中的连接字符串加密的方式提高程序的安全性。Sql Server 2005中的 Sql Server身份验证模式如下:Sql Server 2005中的 Windows 身份验证注意:在使用集成的Windows 验证方式时,并不需要我们输入用户名和口令,而是把登录 Windows时输入的用户名和口令传递到Sql Server。然后 Sql Server检查用户清单,检查其是否具有访问数据库的权限。而且数据库连接字符串是不区分大小写的。名
12、师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 13 页 - - - - - - - - - Sql Server 2005中的 Windows 身份验证如果你使用其他的数据提供者的话,所产生的连接字符串也具有相类似的形式。例如我们希望以OLE DB的方式连接到一个Oracle 数据库,其连接字符串如下:string connectionString = data source=localhost;initial catalog=Sales; use id=sa;passw
13、ord=;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:Northwind.mdb”;程序代码说明:在上述语法范例的程
14、序代码中,通过专门针对Access 数据库的 OLE DB名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 13 页 - - - - - - - - - 提供程序,实现数据库的连接。这使用的的OLE DB提供程序为Microsoft.Jet.OLEDB.4.0,并且数据库存放在c:DataSource目录下,其数据库文件为Northwind.mdb 。现在我们就可以将数据库连接字符串传人SqlConnection()构造函数,例如:string connectionStri
15、ng = 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对象。因此我们也可以设置该对象的ConnectionSt
16、ring属性,为其指定一个数据库连接字符串。这和将数据库连接字符串传人SqlConnection()构造函数的功能是一样的。SqlConnection mySqlConnection = new SqlConnection(); mySqlConnection.ConnectionString = server=localhost;database=Northwind;uid=sa;pwd=sa; 注意:只能在关闭Connection对象时设置ConnectionString属性。打开和关闭数据库连接生成 Connection 对象并将其设置ConnectionString属性设置为数据库连接
17、的相应细节之后,就可以打开数据库连接。为此可以调用Connection对象的 Open() 方法。其方法如下:mySqlConnection.Open(); 完成数据库的连接之后,我们可以调用Connection对象的 Close() 方法关闭数据库连接。例如:mySqlConnection.Close(); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 13 页 - - - - - - - - - 下面是一个显示如何用SqlConnection对象连接 Sql Ser
18、ver Northwind数据库的实例程序,并且显示该SqlConnection对象的一些属性。范例程序代码如下:01 public partial class _Default : System.Web.UI.Page 02 03 protected void Page_Load(object sender, EventArgs e) 04 05 /建立数据库连接字符串06 string connectionString = server=localhost;database=Northwind; 07 integrated security=SSPI; 08 /将连接字符串传入SqlCon
19、nection对象的构造函数中09 SqlConnection mySqlConnection = new SqlConnection(connectionString); 10 try 11 12 /打开连接13 mySqlConnection.Open(); 14 /利用 label控件显示 mySqlConnection对象的 ConnectionString属性15 lblInfo.Text = bmySqlConnection对象的 ConnectionString属性为: b + 16 mySqlConnection.ConnectionString + br ; 17 lblIn
20、fo.Text += bmySqlConnection对象的 ConnectionTimeout属性为 b + 18 mySqlConnection.ConnectionTimeout + br; 19 lblInfo.Text += bmySqlConnection对象的 Database 属性为 b + 20 mySqlConnection.Database + br ; 21 lblInfo.Text += bmySqlConnection对象的 DataSource 属性为 b + 22 mySqlConnection.DataSource + br; 23 lblInfo.Text
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年2022年连接SQLServer数据库详解 2022 连接 SQLServer 数据库 详解
限制150内