一、摘要

为什么取名叫《葵花宝典》?

从行走江湖的世界角度来讲您可以理解为一本"武功秘籍",站在我们IT编程的世界角度应该叫"开发宝典"。

如果您在工作中主要接触的是操作MySQL数据库,但您又想学习和了解.NET轻量级ORM框架Dapper,那么就请跟着阿笨一起学习本次的分享课《.NET轻量级ORM框架Dapper葵花宝典》。Let's Go,Do It ,Dapper For MySQL!

废话不多说,直接上干货,我们不生产干货,我们只是干货的搬运工。

 

二、课程适合人群范围

问:Dapper修炼手册和Dapper葵花宝典这两个课程我该如何选择?

答:结合自身需求,选择合适就好。

2.1《.NET轻量级ORM框架Dapper修炼手册》适合人群如下:

1、我是一个新手,主要工作面向的是MS SQL Server数据库,那么选择修炼手册一定没错。

2、对Dapper从没有过了解或者了解不全面的同学,想通过学习进一步提升对Dapper的认识。

3、迫切想提高下ADO.NET实战技术以及Transact-SQL的编写能力。

4、详细关于Dapper修炼手册可以去之前阿笨公布的公开课中查看课程介绍说明。

2.2、《.NET轻量级ORM框架Dapper葵花宝典》适合人群如下:

1、我是一个新手,主要工作面向的是MySQL数据库,那么选择葵花宝典一定没错。

2、在Dapper修炼手册的基础上新增一个Dapper扩展库Dapper.SimpleCRUD。

3、如何运用Dapper操作Mysql数据库以及Dapper如何支持多数据库。

4、学习Dapper在实际项目常用的几种开发架构模式。(简单三层架构模式、工厂模式、Repository架构模式)

5、本次新增Dapper如何操作处理事务以及优雅的方式使用事务。(强烈推荐)

三、环境准备工作

3.1、mysql for windows数据库安装。

3.2、mysql图形化管理工具介绍和使用。

3.3、mysql监控工具安装和基本使用。

3.4、SqlServer测试数据库转换为Mysql数据库。

1)、使用mss2sql工具将SqlServer转换为Mysql。

2)、Navicat for MySQL 数据导入向导功能。(强烈推荐)

备注:数据导入完成后,一定记得需要重新设置建立自增长列、索引字段以及设置字段的数据类型。

3.5、T4模板引擎基本介绍和简单使用。

四、涉及覆盖的知识点

1、.NET程序员对MySQL数据库的基本认识和理解以及使用。

2、如何通过使用.NET轻量级ORM框架Dapper操作MySQL数据库。

3、Faker.Net仿照测试数据框架运用。

4、VS单元测试NuitTest运用。

5、Dapper在异步编程(Asyn Task)中的运用。

6、原生Dapper简单的CRUD(增删改查) 葵花宝典。(强烈推荐)

7、Dapper扩展库Dapper.SimpleCRUD的基本使用。(强烈推荐)

8、Dapper如何通过DynamicParameters动态拼接查询SQL修炼手册。(强烈推荐)

9、Dapper扩展库Dapper.SqlBuilder、UniqueNamespace.SqlBuilder葵花宝典。(强烈推荐)

10、原生Dapper高级技巧葵花宝典。(强烈推荐)

11、Dapper扩展库Dapper-Extensions葵花宝典。(强烈推荐)

4.1、原生Dapper简单的CRUD(增删改查)

Insert、Insert_Batch(批量插入数据)。

Update、Delete、Exist。

GetById、GetList、GetByIds(in子句使用)。

GetListReturnDynamic(返回dynamic)。

GetListByMultiQuery(返回多结果集Tuple)。

ExecuteWithDBTransaction(本地DbTransaction事务操作)。

ExecuteWithTransactionScope(分布式TransactionScope事务操作)。

4.2、Dapper扩展库Dapper.SimpleCRUD的基本使用

Insert、Delete、Exist、Insert_Batch

GetById、GetList

GetListPaged(获取分页数据,通过Dapper.SimpleCRUD自带的RecordCount、GetListPaged函数分别获取总记录数和分页数据。)

4.3、Dapper如何通过DynamicParameters动态拼接查询SQL修炼手册

Insert、GetListByGenreIdAndName领略DynamicParameters的风采。

SearchOrdersByPageDynamicParametersSqlBuild:获取分页数据(通过DynamicParameters动态拼接查询SQL方式拼接+ ROW_NUMBER() OVER 子句分页)。

4.4、Dapper扩展库Dapper.SqlBuilder修炼手册

通过SqlBuilder构造CRUD语句模板。

通过SqlBuilder内置的模板构造SELECT(查询)、Page(分页)语句模板。

SearchOrdersByPageDapperSqlBuilder:获取分页数据(通过Dapper.SqlBuilder拼接+ limit 子句分页)。

SearchOrdersByDapperDapperSqlBuilderSqlPagingTemplates获取分页数据(通过Dapper.SqlBuilder内置提供的分页模板进行分页)。

4.5、原生Dapper高级技巧修炼手册

CreateOrder:创建订单(采用sql拼接+for循环方式)。

GetOrderOneToManyBySqlBuilder:获取订单(一对多)通过主从表SQL语句方式。

GetOrderOneToManyByDapperQuery:获取订单(一对多)通过原生Dapper Query+splitOn关键字。

SearchOrdersByPageSqlBuild:获取分页数据(通过SQL语句拼接+ limit子句分页)。

4.6、Dapper扩展库Dapper-Extensions修炼手册

1、Insert、Insert_Batch(批量插入数据)。

2、Update、Delete、Exist。

3、GetList:包含如下知识点:

*根据条件进行查询(带过滤条件和排序字段)。

*根据多组合条件进行查询(通过IPredicate的Predicates.Group()生成过滤条件+排序字段)。

*根据多组合条件进行查询(通过IPredicate.Add()生成过滤条件+排序字段)。

*根据多组合条件进行查询(通过Predicate多条件复合谓词组合生成过滤条件+排序字段,示例SQL语句:Select * From Table Where(id1=@id1 AND name2=@name2) OR (id2=@id2 AND name2=@name2)。

*根据单条件进行子查询查询(通过IPredicate.EXISTS()子查询过滤条件语句+排序字段,示例语句:Select * Form Table Where       Exists(Select 1 From Table Where id=@id))。

*根据多组合条件进行子查询查询(通过IPredicate.EXISTS()子查询过滤条件语句+排序字段,示例语句:Select * From Table Where Exists(Select Count(1) From Table Where(id1=@id1 AND name2=@name2) OR (id2=@id2 AND name2=@name2)))。

*SearchOrdersByPageDapperExtensions:获取分页数据(通过提供的扩展DapperExtensions多条件组合复合谓词IPredicate+内置的Count、Page函数)。

六、小结

1、在ADO.NET的世界里"手册"和"宝典"在手,畅行无阻,横行天下。

2、希望学完此本葵花宝典后,您将会汲取到满满的干货,让您更加的有底气!这样阿笨也会感到一丝丝的欣慰。

3、最后阿笨的愿景:力争通过这两次关于Dapper的分享课后,做到目前.NET方面关于Dapper最全面的教程。为.NET的崛起阿笨做一点绵薄之力吧!

4、问:怎样高效的学习《Dapper修炼手册》和《Dapper葵花宝典》?

答:阿笨给出的建议是,您下载源码后需要针对每一个测试用例进行调试和学习,这样您才能了解和熟练的使用Dapper。

.NET轻量级ORM组件Dapper葵花宝典的更多相关文章

  1. .NET轻量级ORM组件Dapper修炼手册

    一.摘要 1.1.为什么叫本次的分享课叫<修炼手册>? 阿笨希望本次的分享课中涉及覆盖的一些小技巧.小技能给您带来一些帮助.希望您在日后工作中把它作为一本实际技能手册进行储备,以备不时之需 ...

  2. .NET轻量级ORM框架Dapper入门精通

    一.课程介绍 本次分享课程包含两个部分<.NET轻量级ORM框架Dapper修炼手册>和<.NET轻量级ORM框架Dapper葵花宝典>,阿笨将带领大家一起领略轻量级ORM框架 ...

  3. 轻量级ORM框架Dapper应用一:Dapper安装

    一.Dapper简介 Dapper是一款轻量级ORM框架,为解决网站访问流量极高而产生的性能问题而构造,主要通过执行TSQL表达式而实现数据库的CQRS. 如果你在项目中遇到性能访问问题,选择Dapp ...

  4. .NET 轻量级 ORM 框架 - Dapper 介绍

    Dapper简单介绍: Dapper is a single file you can drop in to your project that will extend your IDbConnect ...

  5. 基于轻量级ORM框架Dapper的扩展说明

    这里简单的介绍一下本人基于Dapper作的一些简单的扩展,供大家参考. 为何要使用这款框架,相信大家看到下面排名就清楚了 其实在各大网站上,我们大概都会看到这样的一个对比效果图,在超过500次poco ...

  6. 轻量级ORM框架Dapper应用八:使用Dapper实现DTO

    一.什么是DTO 先来看看百度百科的解释: 数据传输对象(DTO)(Data Transfer Object),是一种设计模式之间传输数据的软件应用系统.数据传输目标往往是数据访问对象从数据库中检索数 ...

  7. 轻量级ORM框架Dapper应用六:Dapper支持存储过程

    在Entity Framework中讲解了EF如何支持存储过程,同样,Dapper也支持存储过程,只需要在Query()方法的CommandType中标记使用的是存储过程就可以了.在Users表上面创 ...

  8. 轻量级ORM框架Dapper应用五:使用Dapper实现Join操作

    在这篇文章中,讲解如何使用Dapper使用Inner join的操作 1.新创建两张表:Users表和Product表 Users表定义如下: CREATE TABLE [dbo].[Users]( ...

  9. 轻量级ORM框架Dapper应用四:使用Dapper返回多个结果集

    使用Dapper的QueryMultiple方法可以一次执行多条SQL语句,返回多个结果集,代码如下 using System; using System.Collections.Generic; u ...

随机推荐

  1. TensorFlow 从零到helloWorld

    目录 1.git安装与使用 1.1 git安装 1.2 修改git bash默认路径 1.3 git常用操作 2.环境搭建   2.1 tensorflow安装   2.2 CUDA安装   2.3 ...

  2. TcxGrid 选中 整行

  3. Jenkins 发布.NetCore 项目

    安装最新Jenkins及安装好相关git插件 启动jenkins服务,访问8080端口 这里就发布一个IdentityServer4程序 配置相关参数 设置Git源码管理配置 构建执行window 批 ...

  4. 193 Valid Phone Numbers

    Given a text file file.txt that contains list of phone numbers (one per line), write a one liner bas ...

  5. 《高性能MySQL》学习笔记

    第1章 MySQL架构与历史 1.2 并发控制 MySQL在两个层面实现并发控制:服务器层与存储引擎层. 读锁和写锁: 在处理并发读或写时,可以通过实现一个由两种锁组成的系统来解决问题. 这两种锁通常 ...

  6. 如何简单区分Web前后端与MVC

    MVC是开发所有软件所必须涉及的基本几个划分 M主要负责数据与模型,V主要负责显示C主要负责交互与业务所以不管是前端还是后端,都是有MVC的.MVC是一个对于软件简单的抽象,不管是M还是V,还是C都是 ...

  7. 【LOJ】#2568. 「APIO2016」烟花表演

    题解 这个听起来很毒瘤的想法写起来却非常休闲,理解起来可能很费劲 例如,我们首先到猜到答案是个下凸包 然后是不是要三分???然而并不是orz 我们通过归纳证明这个下凸包的结论来总结出了一个算法 也就是 ...

  8. 【BZOJ】4128: Matrix

    题解 学习一下矩阵求逆 就是我们考虑这个矩阵 \(AA^{-1} = I\) 我们相当于让\(A\)乘上一个矩阵,变成\(I\) 我们可以利用初等行变换(只能应用初等行变换,或只应用初等列变换) 分三 ...

  9. 【AtCoder】ARC093

    C - Traveling Plan 相当于一个环,每次删掉i点到两边的距离,加上新相邻的两个点的距离 代码 #include <bits/stdc++.h> #define fi fir ...

  10. 006.KVM虚机克隆

    一 KVM宿主机内克隆 1.1 查看虚拟机配置 [root@kvm-host ~]# cat /etc/libvirt/qemu/vm01-centos6.8.xml ………… [root@kvm-h ...