​​​​​​​​​​​​​​C#系列-Dapper.Contrib.Extensions应用实例(41)

news/2024/5/17 19:29:57/文章来源:https://blog.csdn.net/zhaoyu_1979/article/details/136118000

 Dapper.Contrib.Extensions 是一个扩展库,它增强了 Dapper 的功能,为 Entity Framework 风格的 CRUD(创建、读取、更新、删除)操作提供了便利的扩展方法。这个库允许你更简单地处理数据库操作,而无需编写大量的样板代码。

下面是一个使用 Dapper.Contrib.Extensions 的应用实例。在这个例子中,我们将展示如何使用这个库来执行基本的 CRUD 操作。

首先,安装 Dapper.Contrib.Extensions NuGet 包:

shell代码

Install-Package Dapper.Contrib.Extensions

然后,定义你的实体类,并为它添加一个主键属性。Dapper.Contrib.Extensions 要求实体类具有一个名为 Id 的主键属性。

csharp代码

public class Blog

{

public int Id { get; set; }

public string Url { get; set; }

public string Title { get; set; }

}

接下来,配置你的数据库连接。在这个例子中,我们将使用 SqlConnection

csharp代码

using System.Data.SqlClient;

var connectionString = "YourConnectionStringHere";

using (var connection = new SqlConnection(connectionString))

{

connection.Open();

// 创建(Insert)

var newBlog = new Blog { Url = "http://example.com", Title = "My Blog" };

newBlog.Id = connection.Insert<Blog>(newBlog);

// 读取(Select)

var blog = connection.Get<Blog>(newBlog.Id);

Console.WriteLine($"Blog Title: {blog.Title}");

// 更新(Update)

blog.Title = "Updated Blog Title";

connection.Update(blog);

// 删除(Delete)

connection.Delete<Blog>(newBlog.Id);

}

在这个例子中,我们首先建立了一个数据库连接,并使用 Insert 方法创建了一个新的博客条目。Insert 方法返回新插入实体的主键值,我们将其存储在 newBlog.Id 属性中。

然后,我们使用 Get 方法根据主键值检索博客条目。接下来,我们修改了博客条目的标题,并使用 Update 方法将其更新到数据库中。

最后,我们使用 Delete 方法根据主键值删除了博客条目。

请注意,Dapper.Contrib.Extensions 默认使用约定来映射数据库表和列名。例如,它会将类名作为表名,将属性名作为列名,并假设主键名为 Id。如果你的数据库表或列名与这些约定不符,你可能需要配置自定义映射或使用属性来指定映射。

此外,确保你的数据库连接字符串是正确的,并且数据库服务器是可用的。

这个示例演示了 Dapper.Contrib.Extensions 提供的基本 CRUD 操作。在实际应用中,你可能还需要处理错误、事务、复杂的查询以及其他高级功能。

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

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

相关文章

网页布局之浮动

一&#xff0c;传统网页布局的三种方式 普通流&#xff08;标准流&#xff09;、浮动、定位。 二&#xff0c;标准流&#xff08;普通流/文档流&#xff09; 即为标签按照规定好的默认方式排列。 1.块级元素会独占一行&#xff0c;从上向下顺序排列。 常用元素&#xff1a;…

Recorder 实现语音录制并上传到后端(兼容PC和移动端)

Recorder 首页&#xff1a;https://github.com/xiangyuecn/Recorder 一、安装 npm install recorder-core二、代码部分 1. HTML页面 <template><div><el-inputv-model"ttsText"type"textarea"placeholder"请输入内容"><…

什么是特征值和特征向量?(done)

什么是齐次方程&#xff1f; https://blog.csdn.net/shimly123456/article/details/136198159 行列式和是否有解的关系&#xff1f; https://blog.csdn.net/shimly123456/article/details/136198215 特征值和特征向量 参考视频&#xff1a;https://www.bilibili.com/video/BV1…

LeetCode 算法题 (数组)存在连续3个奇数的数组

问题&#xff1a; 输入一个数组&#xff0c;并输入长度&#xff0c;判断数组中是否存在连续3个元素都是奇数的情况&#xff0c;如果存在返回存在连续3个元素都是奇数的情况&#xff0c;不存在返回不存在连续3个元素都是奇数的情况 例一&#xff1a; 输入&#xff1a;a[1,2,3…

xilinx除法器的使用

平台&#xff1a;Vivado2018.3. 芯片&#xff1a;xcku115-flva1517-2-i (active) 最近学习使用了xilinx除法器&#xff0c;在使用过程中出现了很多次除法器的结果和我预计的结果不一致&#xff0c;特此记录学习一下。 参考文件&#xff1a;pg151.下载地址 pg151-div-gen.pdf …

论文阅读-Hydra: 用于持久内存和RDMA网络的分散文件系统

论文名称&#xff1a;Hydra: A Decentralized File System for Persistent Memory and RDMA Networks 摘要 新兴的字址持久内存&#xff08;PM&#xff09;有可能颠覆内存和存储之间的边界。结合高速RDMA网络&#xff0c;分布式基于PM的存储系统提供了通过紧密耦合PM和RDMA特…

如何在wxPython应用程序中使用Panda3D

我们知道wxPython提供了丰富的工具和部件来构建用户界面&#xff0c;如果当我们整合wxPython和Panda3D可以创建出功能丰富且交互性强的应用程序&#xff0c;可以创建出强大而丰富的用户界面和3D场景。这样做的主要挑战在于将两个库整合到一个应用程序中&#xff0c;同时确保它们…

【PyQt】12-滑块、计数控件

文章目录 前言一、滑块控件 QSlider运行结果 二、计数器控件 QSpinBox运行结果 总结 前言 1、滑块控件 2、计数控件 一、滑块控件 QSlider #Author &#xff1a;susocool #Creattime:2024/2/15 #FileName:28-滑块控件 #Description: 通过滑块选择字体大小 import sys from PyQ…

解决kkFileView4.4.0版本pdf、word不能预览问题

这里使用的是http下载流url预览&#xff0c;遇到的问题。 官方使用指南&#xff1a;kkFileView - 在线文件预览 1 前端测试代码 1.1 官方示例代码 1.2 本人测试代码 注意&#xff1a;要给预览文件的url进行编码encodeURIComponent(Base64.encode(previewUrl))。 <!DOCTYP…

HTB-Analytics

靶机的IP地址为10.10.11.233&#xff0c;攻击机的IP地址为10.10.16.30 信息收集 # nmap -sT --min-rate 10000 -p- 10.10.11.233 -oN port.nmap Starting Nmap 7.94 ( https://nmap.org ) at 2024-02-19 14:50 CST Warning: 10.10.11.233 giving up on port because retransm…

Code Composer Studio (CCS) - Build All

Code Composer Studio [CCS] - Build All 1. Build AllReferences 1. Build All Project -> Build All (Ctrl B) References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/

Stable Diffusion——stable diffusion基础原理详解与安装秋叶整合包进行出图测试

前言 在2022年&#xff0c;人工智能创作内容&#xff08;AIGC&#xff09;成为了AI领域的热门话题之一。在ChatGPT问世之前&#xff0c;AI绘画以其独特的创意和便捷的创作工具迅速走红&#xff0c;引起了广泛关注。随着一系列以Stable Diffusion、Midjourney、NovelAI等为代表…

力扣题目训练(16)

2024年2月9日力扣题目训练 2024年2月9日力扣题目训练530. 二叉搜索树的最小绝对差541. 反转字符串 II543. 二叉树的直径238. 除自身以外数组的乘积240. 搜索二维矩阵 II124. 二叉树中的最大路径和 2024年2月9日力扣题目训练 2024年2月9日第十六天编程训练&#xff0c;今天主要…

用Python实现简单用户登录操作

下面是小编写的用户登录操作实例代码 实例代码&#xff1a; def pythonit():i 0while i <3 :user input("请输入用户名&#xff1a;")pwd input("请输入密码&#xff1a;")if user "admin" and pwd "123456":print(f"用…

js_三种方法实现深拷贝

深拷贝&#xff08; 递归 &#xff09; 适用于需要完全独立于原始对象的场景&#xff0c;特别是当对象内部有引用类型时&#xff0c;为了避免修改拷贝后的对象影响到原始对象&#xff0c;就需要使用深拷贝。 // 原始对象 const obj { uname: Lily,age: 19,hobby: [乒乓球, 篮球…

企业资产|企业资产管理系统|基于springboot企业资产管理系统设计与实现(源码+数据库+文档)

企业资产管理系统目录 目录 基于springboot企业资产管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、用户信息管理 2、用户审核管理 3、资产分类管理 4、资产信息管理 5、资产信息添加 6、资产借出统计 7、资产归还审核 8、资产维修管理 9、资产维修…

戴尔Dell R740服务器开机冒烟亮黄灯故障维修

今天分享的是一台过保修期的DELL PowerEdge R740服务器开机冒烟的维修案例。先上图&#xff1a; 接到用户报修后工程师立即响应&#xff0c;由于用户也是刚开工第一天服务器开机就出现了这种祥龙吐雾的祥兆&#xff0c;导致工厂业务流程无法正常使用&#xff0c;这台机器在东莞…

微信小程序之会议OA个人中心后台交互

目录 获取用户昵称头像和昵称 小程序登录 登录-小程序 wx.checkSession wx.login wx.request 后台 准备数据表 反向生成工具生成 准备封装前端传过来的数据 小程序服器配置 导入微信小程序SDK application.yml WxProperties WxConfig WxAuthController 登录-小…

java中实体pojo对于布尔类型属性命名尽量别以is开头,否则 fastjson可能会导致属性读取不到

假如我们有一个场景&#xff0c;就是需要将一个对象以字符串的形式&#xff0c;也就是jsonString存到一个地方&#xff0c;比如mysql&#xff0c;或者redis的String结构。现在有一个实体&#xff0c;我们自己创建的&#xff0c;叫做CusPojo.java 有两个属性是布尔类型的&#x…

微信小程序开发:通过wx.login()获取用户唯一标识openid和unionid

下面代码展示了 openid 的获取过程。 想获取 unionid 需要满足条件&#xff1a;小程序已绑定到微信开放平台账号下&#xff0c;不然只会返回 openid。 【相关文档】 微信小程序开发&#xff1a;appid 和 secret 的获取方法 wx.login({success (res) {if (res.code) {// 发起网…