ADO.NET 总结
来源:未知 责任编辑:责任编辑 发表时间:2014-01-06 18:19 点击:次
一、使用DbConnection要记得手工关闭
上次不小心使用DbConnection后忘记手工关闭了,原以为它会合Stream一样,在生命周期结束之后就会自己关闭掉, 但事实证明,不是这样的,看MSDN是这样说的:
See also
Close 方法回滚任何挂起的事务。然后,它将连接释放到连接池,或者在连接池被禁用的情况下关闭连接。 应用程序可以多次调用Close。不会生成任何异常。 如果DbConnection 超出范围,则不会将其关闭。因此,必须通过调用功能上等效的Close 或Dispose 显式关闭该连接。 如果将连接池值Pooling 设置为true 或yes,则也会释放物理连接。 www.2cto.com
二、使用DbProviderFactories并扩充兼容mysql
ADO.NET2.0 为各种ADO.NET类引入了一个提供程序工厂的模型以及通用基类。
ADO.NET通用接口的限制:
• 接口不易扩展ADO.NET1.1无法创建某些类的实例
• ADO.NET1.1无法判断可用的.NET数据提供程序。
提供工厂模型如何解决上述限制
• 通过抽象积累来扩展ADO,NET模型
• 使用DbProviderFactory类来创建对象
提供程序工厂模型的限制
• 许多查询结构都是数据库特有的
• 为参数化查询设置CommandText时,可能需要提供程序特有的代码
• 指定参数数据类型可能需要提供程序特有的代码
为了使开发的代码通用,不局限于特定的数据库,本次开发中决定使用DbProviderFactory+标准SQL, 以开发一个适用于mysql和sqlserver的封装,但DbProviderFactories 并没有提供对mysql的DbProviderFactory的支持, 所以需要扩充DbProviderFactories类兼容mysql, 而且在ADO.net 2.0中mysql和sqlserver的ParameterMarkerFormat都有bug,所以扩展类顺带解决这个bug
public static class DbProviderFactoryEx { public static DbProviderFactoryGetFactory(string providerName) { if (providerName == null) throw newArgumentNullException("providerName"); switch (providerName) { case"MySql.Data.MySqlClient": return new MySqlClientFactory(); default: returnDbProviderFactories.GetFactory(providerName); } } public static stringGetParameterMarkerFormat(DbConnection connect) { if (connect == null) throw newArgumentNullException("connect"); Type type = connect.GetType(); if (type ==typeof(MySql.Data.MySqlClient.MySqlConnection)) returnMySqlParameterMarkerFormat;//mysql bug else if (type ==typeof(System.Data.SqlClient.SqlConnection)) returnSqlServerParameterMarkerFormat;//ms bug connect.Open(); string result =connect.GetSchema("DataSourceInformation").Rows[0]["ParameterMarkerFormat"].ToString(); connect.Close(); return result; } public staticreadonly string SqlServerParameterMarkerFormat = "@{0}"; public static readonlystring MySqlParameterMarkerFormat = "?{0}"; }
三、开启sql2005远程连接功能
连接到SQL Server 2005时,在默认的设置下SQL Server不允许进行远程连接,需要自己手工开启,详细步骤如下: 开始 –> 所有程序 –> Microsoft SQL Server 2005 –> Configuration Tools –> SQL Server Surface Area Configuration –> Surface Area Configuration for Services and Connections –> MSSQLSERVER节点下的Database Engine 节点 –> Remote Connections –> Local and remote connections –> 选择Using Tcp/Ip only 或Using both Tcp/Ip and named pipes
上次不小心使用DbConnection后忘记手工关闭了,原以为它会合Stream一样,在生命周期结束之后就会自己关闭掉, 但事实证明,不是这样的,看MSDN是这样说的:
See also
Close 方法回滚任何挂起的事务。然后,它将连接释放到连接池,或者在连接池被禁用的情况下关闭连接。 应用程序可以多次调用Close。不会生成任何异常。 如果DbConnection 超出范围,则不会将其关闭。因此,必须通过调用功能上等效的Close 或Dispose 显式关闭该连接。 如果将连接池值Pooling 设置为true 或yes,则也会释放物理连接。 www.2cto.com
二、使用DbProviderFactories并扩充兼容mysql
ADO.NET2.0 为各种ADO.NET类引入了一个提供程序工厂的模型以及通用基类。
ADO.NET通用接口的限制:
• 接口不易扩展ADO.NET1.1无法创建某些类的实例
• ADO.NET1.1无法判断可用的.NET数据提供程序。
提供工厂模型如何解决上述限制
• 通过抽象积累来扩展ADO,NET模型
• 使用DbProviderFactory类来创建对象
提供程序工厂模型的限制
• 许多查询结构都是数据库特有的
• 为参数化查询设置CommandText时,可能需要提供程序特有的代码
• 指定参数数据类型可能需要提供程序特有的代码
为了使开发的代码通用,不局限于特定的数据库,本次开发中决定使用DbProviderFactory+标准SQL, 以开发一个适用于mysql和sqlserver的封装,但DbProviderFactories 并没有提供对mysql的DbProviderFactory的支持, 所以需要扩充DbProviderFactories类兼容mysql, 而且在ADO.net 2.0中mysql和sqlserver的ParameterMarkerFormat都有bug,所以扩展类顺带解决这个bug
public static class DbProviderFactoryEx { public static DbProviderFactoryGetFactory(string providerName) { if (providerName == null) throw newArgumentNullException("providerName"); switch (providerName) { case"MySql.Data.MySqlClient": return new MySqlClientFactory(); default: returnDbProviderFactories.GetFactory(providerName); } } public static stringGetParameterMarkerFormat(DbConnection connect) { if (connect == null) throw newArgumentNullException("connect"); Type type = connect.GetType(); if (type ==typeof(MySql.Data.MySqlClient.MySqlConnection)) returnMySqlParameterMarkerFormat;//mysql bug else if (type ==typeof(System.Data.SqlClient.SqlConnection)) returnSqlServerParameterMarkerFormat;//ms bug connect.Open(); string result =connect.GetSchema("DataSourceInformation").Rows[0]["ParameterMarkerFormat"].ToString(); connect.Close(); return result; } public staticreadonly string SqlServerParameterMarkerFormat = "@{0}"; public static readonlystring MySqlParameterMarkerFormat = "?{0}"; }
三、开启sql2005远程连接功能
连接到SQL Server 2005时,在默认的设置下SQL Server不允许进行远程连接,需要自己手工开启,详细步骤如下: 开始 –> 所有程序 –> Microsoft SQL Server 2005 –> Configuration Tools –> SQL Server Surface Area Configuration –> Surface Area Configuration for Services and Connections –> MSSQLSERVER节点下的Database Engine 节点 –> Remote Connections –> Local and remote connections –> 选择Using Tcp/Ip only 或Using both Tcp/Ip and named pipes
相关新闻>>
最新推荐更多>>>
- 发表评论
-
- 最新评论 更多>>