轻量级ORM框架Dapper应用之实现CURD操作
在上一篇文章中,讲解了如何安装Dapper,这篇文章中将会讲解如何使用Dapper使用CURD操作。
例子中使用到的实体类定义如下:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace DapperApplicationDemo.Model{public class User{public int UserId { get; set; }public string UserName { get; set; }public string Email { get; set; }public string Address { get; set; }}}
注意:在使用下面的方法之前要首先引入Dapper的命名空间:Using Dapper;一、插入数据 1、使用匿名类插入数据
IDbConnection connection = new SqlConnection(conn); var result = connection.Execute("Insert into Users values (@UserName, @Email, @Address)",new { UserName = "Tom", Email = "747954712@qq.com", Address = "北京" });
查询数据库:

文章图片
2、使用实体类插入数据
string sqlCommandText = "insert into Users(UserName,Email,Address) Values (@UserName,@Email,@Address)"; using (IDbConnection connection = new SqlConnection(conn)){User user = new User(){UserName = "tim",Email = "78415155@qq.com",Address = "北京"}; int result = connection.Execute(sqlCommandText,user); if (result > 0){Console.WriteLine("插入成功!"); }else{Console.WriteLine("插入失败!"); }}
查询数据库:
【轻量级ORM框架Dapper应用之实现CURD操作】

文章图片
3、InsertBulk操作
既然是Bulk操作,那肯定就是批量插入了,我们要做的就是将上面使用到的“匿名对象”变成“匿名对象集合”就可以了,代码如下:
using (IDbConnection connection = new SqlConnection(conn)){var userList = Enumerable.Range(1012, 100000).Select(i => new User(){Email = i + "qq.com",Address = "北京",UserName = "CK" + i,}); var result = connection.Execute("insert into Users values(@UserName,@Email,@Address)", userList); }
查询数据库:

文章图片
二、查询数据
using (IDbConnection connection = new SqlConnection(conn)){// 查询var query = connection.Query("SELECT * FROM Users"); query.AsList().ForEach(p => {Console.WriteLine("Id:"+p.UserId+" UserName:"+p.UserName+" Email:"+p.Email+" Address:"+p.Address); }); }
程序运行结果:

文章图片
三、更新数据 1、使用匿名类更新
using (IDbConnection connection = new SqlConnection(conn)){var result = connection.Execute("update Users set UserName='Tim',Address='上海' where UserId=@UserId", new { UserId = 2 }); }
查询数据库:

文章图片
2、使用实体类更新
using (IDbConnection connection = new SqlConnection(conn)){User user = new User(); user.UserName = "张无忌"; user.UserId = 1; var result = connection.Execute("update Users set UserName=@UserName where UserId=@UserId", user); }
查询数据库:

文章图片
3、使用键值对更新
using (IDbConnection connection = new SqlConnection(conn)){Listkeys = new List (); keys.Add(new KeyValuePair("@UserName", "风清扬")); keys.Add(new KeyValuePair("@UserId", 2)); var result = connection.Execute("update Users set UserName=@UserName where UserId=@UserId", keys); }
查询数据库:

文章图片
四、删除数据 1、使用匿名类删除数据
using (IDbConnection connection = new SqlConnection(conn)){var result = connection.Execute("delete from Users where UserId=@UserId", new { UserId = 3 }); }
2、使用实体类删除数据
using (IDbConnection connection = new SqlConnection(conn)){User user = new User(); user.UserId = 4; var result = connection.Execute("delete from Users where UserId=@UserId", user); }
示例程序代码下载地址:点此下载
到此这篇关于使用Dapper实现CURD操作的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
推荐阅读
- 计算机网络|网络入门基础模型, 网络大体框架, TCP/IP协议栈, 各种局域网和广域网刨析 (以图解的方式推开网络大门)
- 【.NET6+WPF】WPF使用prism框架+Unity|【.NET6+WPF】WPF使用prism框架+Unity IOC容器实现MVVM双向绑定和依赖注入
- 面向企业级前端应用的开发框架|面向企业级前端应用的开发框架 UI5 的发展简史介绍
- mybatis|mybatis plus框架@TableField注解不生效问题及解决方案
- Pico.css|Pico.css - 简单优雅的纯 CSS 开源 UI 框架,用原始的 HTML 元素标签来做界面
- mybatis|mybatis plus框架的@TableField注解不生效问题总结
- 聊聊Canvas渲染相关|聊聊Canvas渲染相关 (非API层,偏框架设计方面)
- Java中DecimalFormat用法及符号含义
- 福昕软件与中国船级社签署框架合作协议,共建数字船舶发展新高地
- 2022年PhpStorm最新破解教程 -