ADO.NET与ORM的比较(1):ADO.NET实现CRUD

简介:
说明:个人感觉在Java领域大型开发都离不了ORM的身影,所谓的SSH就是Spring+Struts+Hibernate,除了在学习基础知识的时候被告知可以使用JDBC操作数据库之外,大量的书籍中都是讲述使用Hibernate这个ORM工具来操作数据。在.NET中操作数据库的方式有多种,除了最直接的方式就是使用ADO.NET之外,还可以使用NHibernate这个Hibernate在.NET中的实现ORM,如果你对第三方的ORM持怀疑态度,你还可以使用来自微软的实现、根正苗红的Linq或者EntityFramework。
大部分从早期就开始使用.NET开发的程序员可能对ADO.NET有种迷恋,使用ADO.NET可以充分将我们早期的SQL知识发挥得淋漓尽致,并且出于对性能的考虑,有些人对.NET中的ORM还保持一种观望态度,包括我自己也是这种态度。不过即使在实际开发中不用,并不代表我们不能去了解和比较这些技术,任何事物的出现和消亡总有其原因的,我们可以了解它们的优点和长处。所以本人抽出了几个周末的时间分别用ADO.NET、NHibernate、Linq和EntityFramework来实现对数据库单表数据的创建、读取、更新和删除操作,也就是所谓的CRUD(C:Create/R:Read/U:Update/D:Delete)。
通过实现相同功能的比较,大家自己判断那种方式更适合自己。需要说明的是,如果在VS2008中使用EntityFramework就需要安装VS2008SP1。
在开始演示之前先准备好数据,在本系列中所使用的数据库是SQL Server2005,创建和初始化数据库数据的代码如下:
/****** 对象:    Table [dbo].[UserInfo]        脚本日期: 03/08/2010 12:20:11 ******/ 
SET ANSI_NULLS  ON 
GO 
SET QUOTED_IDENTIFIER  ON 
GO 
IF  NOT  EXISTS ( SELECT *  FROM sys.objects  WHERE  object_id =  OBJECT_ID(N '[dbo].[UserInfo]'AND type  in(N 'U')) 
BEGIN 
CREATE  TABLE [dbo].[UserInfo]( 
  [UserID] [ int] IDENTITY(1,1)  NOT  NULL
  [UserName] [ varchar](20)  COLLATE Chinese_PRC_CI_AS  NOT  NULL
  [RealName] [ nvarchar](8)  COLLATE Chinese_PRC_CI_AS  NOT  NULL
  [Age] [ tinyintNOT  NULL
  [Sex] [ bitNOT  NULL
  [Mobile] [ char](11)  COLLATE Chinese_PRC_CI_AS  NULL
  [Phone] [ char](11)  COLLATE Chinese_PRC_CI_AS  NULL
  [Email] [ varchar](50)  COLLATE Chinese_PRC_CI_AS  NOT  NULL
CONSTRAINT [PK_UserInfo]  PRIMARY  KEY  CLUSTERED    

  [UserID]  ASC 
) WITH (IGNORE_DUP_KEY =  OFF

END 
GO 
IF  NOT  EXISTS ( SELECT *  FROM sys.indexes  WHERE  object_id =  OBJECT_ID(N '[dbo].[UserInfo]'AND  name= N 'IX_UserName'
CREATE  UNIQUE  NONCLUSTERED  INDEX [IX_UserName]  ON [dbo].[UserInfo]    

  [UserName]  ASC 
) WITH (IGNORE_DUP_KEY =  ON
GO
 
下面开始演示如何使用ADO.NET实现CRUD功能。
一、配置
创建一个控制台或者类库项目,并且添加一个app.config配置文件,在此文件中添加数据库配置信息,如下:
< connectionStrings > 
   < add  name ="Conn"  connectionString ="Data Source=zhou;Initial Catalog=AspNetStudy;User ID=sa;Password=jerry"  /> 
</ connectionStrings >
 
二、创建实体类
using System; 
using System.Collections.Generic; 
using System.Text; 
 
namespace ADODoNETDemo 

         public  class UserInfo 
        { 
                 /// <summary> 
                 /// 用户编号 
                 /// </summary> 
                 public  int UserId { get; set; } 
                 /// <summary> 
                 /// 用户名 
                 /// </summary> 
                 public  string UserName { get; set; } 
                 /// <summary> 
                 /// 真实姓名 
                 /// </summary> 
                 public  string RealName { get; set; } 
                 /// <summary> 
                 /// 年龄 
                 /// </summary> 
                 public  byte Age { get; set; } 
                 /// <summary> 
                 /// 性别 
                 /// </summary> 
                 public  bool Sex { get; set; } 
                 /// <summary> 
                 /// 电子邮件 
                 /// </summary> 
                 public  string Email { get; set; } 
                 /// <summary> 
                 /// 手机号 
                 /// </summary> 
                 public  string Mobile { get; set; } 
                 /// <summary> 
                 /// 电话 
                 /// </summary> 
                 public  string Phone { get; set; } 
        } 
}
 
三、创建数据库访问通用类
说明:下面的这个数据库通用类适用于访问数据库中任意表,不管是基于文本方式SQL、参数化SQL语句或者存储过程都可以。
很郁闷受篇幅限制,这里将代码放在附件里。
四、创建CRUD类
对数据库实现增删改查功能的类的代码如下:
using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Data.SqlClient; 
using System.Data; 
 
namespace ADODoNETDemo 

         /// <summary> 
         /// 用ADO.NET实现CRUD功能 
         /// </summary> 
         public  class ADODotNetCRUD 
        { 
                 /// <summary> 
                 /// 统计用户总数 
                 /// </summary> 
                 /// <returns></returns> 
                 public  int Count() 
                { 
                         string sql =  "select count(1) from UserInfo"
                        SqlDbHelper db =  new SqlDbHelper(); 
                         return  int.Parse(db.ExecuteScalar(sql).ToString()); 
                } 
                 /// <summary> 
                 /// 创建用户 
                 /// </summary> 
                 /// <param name="info">用户实体</param> 
                 /// <returns></returns> 
                 public  bool Create(UserInfo info) 
                { 
                         string sql =  "insert UserInfo(UserName,RealName,Age,Sex,Mobile,Email,Phone)values(@UserName,@RealName,@Age,@Sex,@Mobile,@Email,@Phone)"
                        SqlParameter[] paramters =  new SqlParameter[]{ 
                                 new SqlParameter( "@UserName",info.UserName), 
                                 new SqlParameter( "@RealName",info.RealName), 
                                 new SqlParameter( "@Age",info.Age), 
                                 new SqlParameter( "@Sex",info.Sex), 
                                 new SqlParameter( "@Mobile",info.Mobile), 
                                 new SqlParameter( "@Email",info.Email), 
                                 new SqlParameter( "@Phone",info.Phone), 
                        }; 
                        SqlDbHelper db =  new SqlDbHelper(); 
                         return db.ExecuteNonQuery(sql, CommandType.Text, paramters) > 0; 
                } 
                 /// <summary> 
                 /// 读取用户信息 
                 /// </summary> 
                 /// <param name="userId">用户编号</param> 
                 /// <returns></returns> 
                 public UserInfo Read( int userId) 
                { 
                         string sql =  "select * from UserInfo Where UserId="+userId; 
                        SqlDbHelper db =  new SqlDbHelper(); 
                        DataTable data = db.ExecuteDataTable(sql); 
                         if (data.Rows.Count > 0) 
                        { 
                                DataRow row = data.Rows[0]; 
                                UserInfo info =  new UserInfo() 
                                { 
                                        UserId= int.Parse(row[ "UserId"].ToString()), 
                                        UserName=row[ "UserName"].ToString(), 
                                        Age= byte.Parse(row[ "Age"].ToString()), 
                                        Email=row[ "Email"].ToString(), 
                                        Mobile=row[ "Mobile"].ToString(), 
                                        Phone=row[ "Phone"].ToString(), 
                                        RealName=row[ "RealName"].ToString(), 
                                        Sex= bool.Parse(row[ "Sex"].ToString()) 
                                }; 
                                 return info; 
                        } 
                         else 
                        { 
                                 return  null
                        } 
                } 
                 /// <summary> 
                 /// 更新用户信息 
                 /// </summary> 
                 /// <param name="info">用户实体</param> 
                 /// <returns></returns> 
                 public  bool Update(UserInfo info) 
                { 
                         string sql =  "update UserInfo set UserName=@UserName,RealName=@RealName,Age=@Age,Sex=@Sex,Mobile=@Mobile,Email=@Email,Phone=@Phone where UserID=@UserID"
                        SqlParameter[] paramters =  new SqlParameter[]{ 
                                 new SqlParameter( "@UserName",info.UserName), 
                                 new SqlParameter( "@RealName",info.RealName), 
                                 new SqlParameter( "@Age",info.Age), 
                                 new SqlParameter( "@Sex",info.Sex), 
                                 new SqlParameter( "@Mobile",info.Mobile), 
                                 new SqlParameter( "@Email",info.Email), 
                                 new SqlParameter( "@Phone",info.Phone), 
                                 new SqlParameter( "@UserID",info.UserId), 
                        }; 
                        SqlDbHelper db =  new SqlDbHelper(); 
                         return db.ExecuteNonQuery(sql, CommandType.Text, paramters) > 0; 
                } 
                 /// <summary> 
                 /// 删除用户 
                 /// </summary> 
                 /// <param name="userId">用户编号</param> 
                 /// <returns></returns> 
                 public  bool Delete( int userId) 
                { 
                         string sql =  "delete from UserInfo where UserId=" + userId; 
                        SqlDbHelper db =  new SqlDbHelper(); 
                         return db.ExecuteNonQuery(sql) > 0; 
                } 
                 /// <summary> 
                 /// 获取用户表中编号最大的用户 
                 /// </summary> 
                 /// <returns></returns> 
                 public  int GetMaxUserId() 
                { 
                         string sql =  "select max(userId) from UserInfo"
                        SqlDbHelper db =  new SqlDbHelper(); 
                         return  int.Parse(db.ExecuteScalar(sql).ToString()); 
                } 
        } 
}
五、NUnit单元测试代码
在进行单元测试时没有使用VS自带的单元测试工具,仍是我平常用惯了的NUnit,下面是代码:
很遗憾,受篇幅限制,这里代码也以附件形式提供。
六、点评

在使用ADO.NET操作数据库时个人觉得有如下优点,可以随心所欲地使用熟知的SQL语句甚至是存储过程,在使用统计、分组功能时感觉尤其强烈,当然前提是你的SQL基础要相当好,此外它是其它几种ORM的基础,其它几种ORM都是在底层使用ADO.NET实现与数据库的交互的,所以在效率上来说它也要高一些。它的缺点是需要自己写操作数据的语句并且需要自己编写数据库记录到实体的映射转换代码,一旦表的结构发生变动,就需要修改实体类和映射转换代码。

















本文转自周金桥51CTO博客,原文链接: http://blog.51cto.com/zhoufoxcn/283952,如需转载请自行联系原作者


相关文章
|
3月前
|
SQL 开发框架 数据库
".NET开发者的超能力:AgileEAS.NET ORM带你穿越数据库的迷宫,让数据操作变得轻松又神奇!"
【8月更文挑战第16天】AgileEAS.NET是面向.NET平台的企业应用开发框架,核心功能包括数据关系映射(ORM),允许以面向对象方式操作数据库,无需编写复杂SQL。通过继承`AgileEAS.Data.Entity`创建实体类对应数据库表,利用ORM简化数据访问层编码。支持基本的CRUD操作及复杂查询如条件筛选、排序和分页,并可通过导航属性实现多表关联。此外,提供了事务管理功能确保数据一致性。AgileEAS.NET的ORM简化了数据库操作,提升了开发效率和代码可维护性。
51 5
|
21天前
|
SQL 开发框架 关系型数据库
值得推荐的.NET ORM框架
值得推荐的.NET ORM框架
|
3月前
|
缓存 数据库连接 API
Entity Framework Core——.NET 领域的 ORM 利器,深度剖析其最佳实践之路
【8月更文挑战第28天】在软件开发领域,高效的数据访问与管理至关重要。Entity Framework Core(EF Core)作为一款强大的对象关系映射(ORM)工具,在 .NET 开发中扮演着重要角色。本文通过在线书店应用案例,展示了 EF Core 的核心特性和优势。我们定义了 `Book` 实体类及其属性,并通过 `BookStoreContext` 数据库上下文配置了数据库连接。EF Core 提供了简洁的 API,支持数据的查询、插入、更新和删除操作。
106 0
|
6月前
|
XML 开发框架 .NET
C# .NET面试系列八:ADO.NET、XML、HTTP、AJAX、WebService
## 第二部分:ADO.NET、XML、HTTP、AJAX、WebService #### 1. .NET 和 C# 有什么区别? .NET(通用语言运行时): ```c# 定义:.NET 是一个软件开发框架,提供了一个通用的运行时环境,用于在不同的编程语言中执行代码。 作用:它为多语言支持提供了一个统一的平台,允许不同的语言共享类库和其他资源。.NET 包括 Common Language Runtime (CLR)、基础类库(BCL)和其他工具。 ``` C#(C Sharp): ```c# 定义: C# 是一种由微软设计的面向对象的编程语言,专门为.NET 平台开发而创建。 作
297 2
|
11月前
|
SQL 开发框架 关系型数据库
16个值得推荐的.NET ORM框架
16个值得推荐的.NET ORM框架
576 1
|
6月前
|
存储 开发框架 .NET
Asp.net就业课之Ado.net第一次课
Asp.net就业课之Ado.net第一次课
41 0
|
6月前
|
安全 数据库 数据安全/隐私保护
七天.NET 8操作SQLite入门到实战 - 第五天引入SQLite-net ORM并封装常用方法
七天.NET 8操作SQLite入门到实战 - 第五天引入SQLite-net ORM并封装常用方法
185 0
|
2月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
36 7
|
2月前
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
52 0