Dapper的基本使用

Dapper是.NET下一个micro的ORM,它和Entity Framework或Nhibnate不同,属于轻量级的,并且是半自动的。也就是说实体类都要自己写。它没有复杂的配置文件,一个单文件就可以了。给出官方地址。

http://code.google.com/p/dapper-dot-net/

个人觉得他非常好用,现在已经取代了原来的SqlHelper。优点:

  1. 使用Dapper可以自动进行对象映射!
  2. 轻量级,单文件。
  3. 支持多数据库。
  4. Dapper原理通过Emit反射IDataReader的序列队列,来快速的得到和产生对象。

网上还有对Dapper的扩展类,这里就不赘述了。下面只讲下简单的增删改查、数据库表间的对应关系和事务的应用。

先给出实体类的关系:

 书和书评是1---n的关系。(沿用Entity Framework的实体类,virtual表示延迟加载,此处忽略)

复制代码
//书
public class Book{public Book(){Reviews = new List<BookReview>();}public int Id { get; set; }public string Name { get; set; }public virtual List<BookReview> Reviews { get; set; }public override string ToString(){return string.Format("[{0}]------《{1}》", Id, Name);}}//书评public class BookReview{public int Id { get; set; }public int BookId { get; set; }public virtual string Content { get; set; }public virtual Book AssoicationWithBook { get; set; }public override string ToString(){return string.Format("{0})--[{1}]\t\"{3}\"", Id, BookId, Content);}}
复制代码
  • 基本的增删改查操作

  由于Dapper ORM的操作实际上是对IDbConnection类的扩展,所有的方法都是该类的扩展方法。所以在使用前先实例化一个IDBConnection对象。

IDbConnection conn = new SqlConnection(connString);

Insert

复制代码
 Book book = new Book();book.Name="C#本质论";string query = "INSERT INTO Book(Name)VALUES(@name)";
//对对象进行操作conn.Execute(query, book);
//直接赋值操作conn.Execute(query, new {name = "C#本质论"});
复制代码

update

string query = "UPDATE Book SET  Name=@name WHERE id =@id";conn.Execute(query, book);

delete

string query = "DELETE FROM Book WHERE id = @id";
conn.Execute(query, book);
conn.Execute(query, new { id = id });

query

复制代码
 string query = "SELECT * FROM Book";
//无参数查询,返回列表,带参数查询和之前的参数赋值法相同。conn.Query<Book>(query).ToList();//返回单条信息string query = "SELECT * FROM Book WHERE id = @id";book = conn.Query<Book>(query, new { id = id }).SingleOrDefault();     
复制代码
  • 数据库表对应关系操作
复制代码
//查询图书时,同时查找对应的书评,并存在List中。实现1--n的查询操作
string query = "SELECT * FROM Book b LEFT JOIN BookReview br ON br.BookId = b.Id WHERE b.id = @id";
Book lookup = null;
//Query<TFirst, TSecond, TReturn>var b = conn.Query<Book, BookReview, Book>(query,(book, bookReview) =>{//扫描第一条记录,判断非空和非重复if (lookup == null || lookup.Id != book.Id)lookup = book;//书对应的书评非空,加入当前书的书评List中,最后把重复的书去掉。if (bookReview != null)lookup.Reviews.Add(bookReview);return lookup;}, new { id = id }).Distinct().SingleOrDefault();
return b;
复制代码
复制代码
//1--1操作 
BookReview br;
string query = "SELECT * FROM BookReview WHERE id = @id";
using (conn)
{br = conn.Query<BookReview, Book, BookReview>(query,(bookReview, book) =>{bookReview.AssoicationWithBook = book;return bookReview;}, new { id = id }).SingleOrDefault();return br;
}
复制代码
  • 事务操作
复制代码
using (conn)
{
//开始事务
IDbTransaction transaction = conn.BeginTransaction();try{string query = "DELETE FROM Book WHERE id = @id";string query2 = "DELETE FROM BookReview WHERE BookId = @BookId";conn.Execute(query2, new { BookId = id }, transaction, null, null);conn.Execute(query, new { id = id }, transaction, null, null);//提交事务transaction.Commit();}catch (Exception ex){//出现异常,事务Rollbacktransaction.Rollback();throw new Exception(ex.Message);}
}
复制代码

后续文章

  1. 《利用Dapper ORM搭建三层架构》
  2. 《Stackoverflow/dapper的Dapper-Extensions用法(一)》

由于自己的毕设也是用它来写的,所以放出来,可以作为一个实例来参考一下。

sql server2012 + dapper + asp.net mvc4 + easyUI的药库管理系统,有兴趣的可以star一下哦~

转载于:https://www.cnblogs.com/webenh/p/7837777.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/454187.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

函数名作为参数传递

假如不知道signal的函数原型&#xff0c;考虑child_handler函数的参数从哪里来&#xff1f; void child_handler(int sig) { if (sig SIGINT) kill(pid_parent, SIGUSR1); } int main(void) { ...... signal(SIGINT, child_handler); ...... } 1、…

易语言神经网络验证码识别_递归神经网络 GRU+CTC+CNN 教会验证码识别

利用 NLP 技术做简单数据可视化分析Chat 简介&#xff1a;用递归神经网络采用端到端识别图片文字&#xff0c;递归神经网络大家最早用 RNN &#xff0c;缺陷造成梯度消失问题&#xff1b;然后采用了 LSTM&#xff0c;解决 RNN 问题&#xff0c;并且大大提高准确率&#xff1b;现…

GCC 生成的符号表调试信息剖析

GCC把C语言源文件&#xff08;&#xff07;.c&#xff07;&#xff09;编译成汇编语言文件&#xff08;&#xff07;.s&#xff07;&#xff09;&#xff0c;汇编器把汇编语言文件翻译成目标文件&#xff08;&#xff07;.o&#xff07;&#xff09;&#xff0c;最后由链接器链…

《操作系统》OS学习(一):OS相关

清华大学操作系统OS&#xff08;向勇、陈渝&#xff09;视频地址&#xff1a;http://www.xuetangx.com/courses/course-v1:TsinghuaX30240243Xsp/about 在ucore实验中&#xff0c;一些基本的常用工具如下&#xff1a; 命令行shell: bash shell -- 有对文件和目录操作的各种命令…

Android4.0蓝牙使能的详细解析

毫无疑问&#xff0c;bluetooth的打开是在Settings中进行的操作。因此&#xff0c;冤有头&#xff0c;债有主&#xff0c;我们来到了Settings.java中&#xff0c;果然发现了相关的代码如下&#xff1a; mBluetoothEnabler new BluetoothEnabler(context, new Switch(context));…

第一次冲刺

本人小组分工角色&#xff1a;产品负责人 本组冲刺订单介绍&#xff1a;经过小组的成员讨论&#xff0c;我们大概确立了一个冲刺的订单是完成一个简易的长沙学院网站项目。 最后完成情况概述&#xff1a;经过大约两周的努力&#xff0c;我们组的编程人员运用python构建了一个简…

移动端导出excel_连载系列【4】Excel开发移动端quot;APPquot;

前三篇文章介绍了百度地图生成器、源代码编辑器、GPS经纬度批量转换工具、源代码编辑器中添加自定义功能按钮和地图控件。这些写好的Java Script代码虽然可以实现所有期望的结果&#xff0c;但毕竟不是一个HTML文件&#xff0c;不便于传播和使用&#xff0c;更无法变成一个类似…

《操作系统》OS学习(二):启动、中断、异常

Bootloader:加载OS。操作系统一开始是放在DISK&#xff08;硬盘&#xff09;中&#xff0c;并不是放在内存中。 BIOS&#xff1a;基本I/O处理系统。存放在ROMRead-Only Memory&#xff09;只读存储中 BIOS&#xff08;Basic Input/Output System&#xff09;基本输入输出系统。…

[GCC for C]编译选项---IDE掩盖下的天空

编译选项 ---------IDE掩盖下的天空 /*************************************** * gcc for c language ***************************************/ Single Source to Executable $ gcc helloworld.c [-o howdy] 默认生成的名字a.exe ______________________________________ …

2016级算法第二次上机-F.ModricWang's Number Theory II

891 ModricWangs Number Theory II 思路 使得序列的最大公约数不为1&#xff0c;就是大于等于2&#xff0c;就是找到一个大于等于2的数&#xff0c;它能够整除序列中的所有数。 考虑使得一个数d整除数组中所有数的代价&#xff1a; 如果一个数不能被b整除&#xff0c;那么可以花…

常用css属性集(持续更新…)

禁止换行&#xff0c;超出部分显示…&#xff1a;a. 代码&#xff1a;.hide_word{ max-width: 100px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; } b. 效果&#xff1a; 本文转自 bilinyee博客&#xff0c;原文链接&#xff1a; http://blog.51cto.co…

parallels网络初始化失败_33 个神经网络「炼丹」技巧

自然语言处理Andrej Karpathy 是深度学习计算机视觉领域、与领域的研究员。博士期间师从李飞飞。在读博期间&#xff0c;两次在谷歌实习&#xff0c;研究在 Youtube 视频上的大规模特征学习&#xff0c;2015 年在 DeepMind 实习&#xff0c;研究深度强化学习。毕业后&#xff0…

《操作系统》OS学习(三):系统调用

例子 首先看一个标准C库的例子&#xff1a;当我们程序中使用了C库中的printf()函数&#xff0c;实际在底层是在内核态中调用了write()函数。图中右侧则是将程序代码与C库都算到应用程序中&#xff0c;内核提供了一个系统调用接口。 从这个例子我们可以得到以下几点&#xff1a…

cygwin/gcc与MinGW

cygwin/gcc和MinGW都是gcc在windows下的编译环境&#xff0c;但是它们有什么区别?在实际工作中如何选择这两种编译器呢?cygwin/gcc完全可以和在linux下的gcc划等号&#xff0c;这个从boost库的划分中就可以看出来端倪&#xff0c;cygwin下的gcc和linux下的gcc使用的是相同的T…

JavaScript服务器端开发技术(对象属性的枚举与查询)

既然对象是属性的集合&#xff0c;那么检测与枚举集合中的属性就是一项重要任务。对此&#xff0c;我们来分别看一下ES3和ES5提供的解决方案。 1) ES3枚举方案 示例代码&#xff1a; var contacts{ ID:[0,1,2,3,4,5], names:["Zero","One","Two&q…

treelistview 所有节点失去焦点_垃圾询盘过滤,焦点科技的 Milvus 实践

文章作者&#xff1a;黎阳&#xff0c;焦点科技软件开发工程师李成龙&#xff0c;Zilliz 数据工程师Milvus (https://milvus.io/) 向量搜索引擎开源半年以来&#xff0c;全球已经有数百家企业或组织用户。焦点科技是一家以 B2B 外贸交易为主营业务的科技公司&#xff0c;也是 M…

《操作系统》OS学习(四):计算机体系结构、内存层次和地址生成

计算机除了计算能力之外还有存储能力&#xff0c;存储能力即计算机拥有一系列的存储介质&#xff0c;我们可以在存储介质上存储我们的代码和数据。计算机体系结构中约定了哪些地方可以用来存储数据&#xff1a;CPU内的寄存器、内存和外存。不同的存储介质&#xff0c;容量、速度…

GCC中SIMD指令的应用方法

X86架构上的多媒体应用开发&#xff0c;如果能够使用SIMD指令进行优化&#xff0c; 性能将大大提高。目前&#xff0c;IA-32的SIMD指令包括MMX&#xff0c;SSE&#xff0c;SSE2等几级。 在GCC的开发环境中&#xff0c;有几种使用SIMD指令的方式&#xff0c;本文逐一介绍。X86的…

使用angular4和asp.net core 2 web api做个练习项目(二), 这部分都是angular

上一篇: http://www.cnblogs.com/cgzl/p/7755801.html 完成client.service.ts: import { Injectable } from angular/core; import { Http, Headers } from angular/http; import { Observable } from rxjs/Observable; import { ErrorHandler } from angular/core; import rxj…

leelen可视对讲怎么接线_楼宇对讲系统怎么布线 楼宇对讲系统布线方式【介绍】...

随着智能小区规模不断增加&#xff0c;楼宇可视对讲系统应用越来越广泛&#xff0c;因而视频信号的传输方式与布线设计显得越来越重要。视频信号与数据和音频信号不同&#xff0c;可行的一种传输方式为视频信号基带传输&#xff0c;下面小编就简要介绍一下这种传输方式和布线方…