首页 技术 正文
技术 2022年11月6日
0 收藏 674 点赞 569 浏览 2003 个字

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

使用:在项目中nuget下载即可,dapper如何使用呢?它和EF不同,我们什么的配置都需要手写,连接配置,实体,上下文,这和ADO.NET有一点相似点。

实战:

 配置Users表

create databaseTextInfo
USE TEXTINFO
create table Users
(
UserID INT IDENTITY(1,1) NOT NULL,
UserName varchar(50) Null,
Email [varchar](100) Null,
[Address] [varchar](100) Null
)

 创建连接字符串

<connectionStrings>
<add name="CnnhoRechargePlatformConnectionString" connectionString="Data Source=DESKTOP-OEJGKOO;Initial Catalog=TextInfo;Integrated Security=True"/>
</connectionStrings>

IDbConnection说明  

//读取config中的字符串
string connstr = ConfigurationManager.ConnectionStrings["CnnhoRechargePlatformConnectionString"].ToString();
//IDbConnection
IDbConnection connection = new SqlConnection(connstr);

我们都知道Sqlconnection继承了DbConnection,那我们再去DbConnection中一探究竟,发现DbConnection继承于IDbConnection,所以呢dapper就是通过这种方式进行了多数据的封装,dapper就是实现了这种接口支持多数据库的特性也就产生了!

【快速入门ORM框架之Dapper】大牛勿进系列

【快速入门ORM框架之Dapper】大牛勿进系列

Insert插入与InsertBulk

insert:

 var result = connection.Execute("insert into Users values(@UserName,@Email,@Address)",new { UserName = "zara",Email="zaranet@163.com",Address="上海浦东"});

【快速入门ORM框架之Dapper】大牛勿进系列

在这里支持匿名对象传入进行插入,非常的人性化哈!你可以发现dapper我们又开始写sql了,没错,这个博主上面没有提到,我们从微软的高度封装中逃了出来?可以这么比喻!对吧。。

insertBulk:

既然是Bulk操作,那一定是批量操作了,我们就可以把这个匿名对象编程匿名对象集合,这样就OK了

var userList = Enumerable.Range(0, 10).Select(i => new
{
Email = "zaranet@qq.com",
Address = "安徽",
UserName = "jack"
}); var result = connection.Execute("insert into Users values(@UserName,@Email,@Address)",userList);

 这样我们就插入了10个,这种操作为了demo,其道理也是非常得离谱。

Query(select)

为了查询我们定义一个UserModel

 public class User
{
public int UserID { get; set; }
public string UserName { get; set; }
public string Email { get; set; }
public string Address { get; set; }
}
 var query = connection.Query<User>("select * from Users where UserName = @userName",new { UserName = "zara" });

【快速入门ORM框架之Dapper】大牛勿进系列

Update(Edit)

这个操作和上面的几乎没什么差别就是改了下sql

 var query = connection.Query<User>("update Users set UserName='zzh' where UserName = @UserName",new { UserName = "zara" });

Delete

这个操作和上面也差不多,非常简单的哈。

 var query = connection.Query<User>("delete  * from Users where UserName = @UserName",new { UserName = "zara" });

好了,希望你看完本片文章会让你对dapper有一个基本的认识,如果觉得写的可以话,点个赞吧!

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,997
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,511
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,356
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,139
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,770
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,848