Dapper是一款轻量级ORM工具(Github)。如果你在小的项目中,使用Entity Framework、NHibernate 来处理大数据访问及关系映射,未免有点杀鸡用牛刀。你又觉得ORM省时省力,这时Dapper 将是你不二的选择。
为什么选择Dapper
- 轻量。只有一个文件(SqlMapper.cs),编译完成之后只有120k(好象是变胖了)
- 速度快。Dapper的速度接近与IDataReader,取列表的数据超过了DataTable。
- 支持多种数据库。Dapper可以在所有Ado.net Providers下工作,包括sqlite, sqlce, firebird, oracle, MySQL, PostgreSQL and SQL Server
- 可以映射一对一,一对多,多对多等多种关系。
- 性能高。通过Emit反射IDataReader的序列队列,来快速的得到和产生对象,性能不错。
- 支持FrameWork2.0,3.0,3.5,4.0,4.5
Dapper的安装
方法一:使用NuGet安装
打开visual studio的项目,依次点击工具
,NuGet包管理器
,管理解决方案的NuGet程序包
;
再点击浏览
,搜索dapper
,点击搜索结果中的Dapper
,勾选项目
,选择安装
;
在解决方案管理器中点击项目
,查看引用
,如果有Dapper
,说明安装成功。
方法二:直接在官网[2]下载源代码,加入项目。这种方法哈希君没有试,不过可以参考链接Dapper快速学习
Dapper的基本用法
插入操作
将一个对象person插入数据库的方法如图。
插入代码文本如下。@Name的意思是自动将person里的Name值绑定上去。
public static int Insert(Person person) { using (IDbConnection connection = new SqlConnection(connectionString)) { return connection.Execute("insert into Person(Name,Remark) values(@Name,@Remark)", person); } }
批量插入:
/// <summary> /// 批量插入Person数据,返回影响行数 /// </summary> /// <param name="persons"></param> /// <returns>影响行数</returns> public static int Insert(List<Person> persons) { using (IDbConnection connection = new SqlConnection(connectionString)) { return connection.Execute("insert into Person(Name,Remark) values(@Name,@Remark)", persons); } }
删除操作
public static int Delete(Person person) { using (IDbConnection connection = new SqlConnection(connectionString)) { return connection.Execute("delete from Person where id=@ID", person); } } public static int Delete(List<Person> persons) { using (IDbConnection connection = new SqlConnection(connectionString)) { return connection.Execute("delete from Person where id=@ID", persons); } }
修改操作
public static int Update(Person person) { using (IDbConnection connection = new SqlConnection(connectionString)) { return connection.Execute("update Person set name=@name where id=@ID", person); } } public static int Update(List<Person> persons) { using (IDbConnection connection = new SqlConnection(connectionString)) { return connection.Execute("update Person set name=@name where id=@ID", persons); } }
查询操作
/// <summary> /// 无参查询所有数据 /// </summary> /// <returns></returns> public static List<Person> Query() { using (IDbConnection connection = new SqlConnection(connectionString)) { return connection.Query<Person>("select * from Person").ToList(); } } /// <summary> /// 查询指定数据 /// </summary> /// <param name="person"></param> /// <returns></returns> public static Person Query(Person person) { using (IDbConnection connection = new SqlConnection(connectionString)) { return connection.Query<Person>("select * from Person where id=@ID",person).SingleOrDefault(); } }
Dapper的复杂操作
查询的In操作
/// <summary> /// In操作 /// </summary> public static List<Person> QueryIn() { using (IDbConnection connection = new