Dapper的牛逼就不扯蛋了,答应群友做个入门Demo的,现有园友需要,那么公开分享一下:

完整Demo:http://pan.baidu.com/s/1i3TcEzj

注 意 事 项:http://www.cnblogs.com/dunitian/p/5221058.html

平台之大势何人能挡? 带着你的Net飞奔吧!

http://www.cnblogs.com/dunitian/p/4822808.html#skill

扩展篇:http://www.cnblogs.com/dunitian/p/5710382.html

先安装一下Dapper(建议用nuget包来管理)

连接字符串:

string connStr = "Data Source=.;Initial Catalog=DapperDB;User ID=用户名;Password=密码";

强类型:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#region 强类型
            //public static IEnumerable<T> Query<T>(this IDbConnection cnn, string sql, object param = null, SqlTransaction transaction = null, bool buffered = true)
            using (SqlConnection conn = new SqlConnection(connStr))
            {
                conn.Open();
                //无参查询
                //var qqModeList = conn.Query<QQModel>("select Id,Name,Count from QQModel");
                //带参查询
                var qqModeList = conn.Query<QQModel>("select Id,Name,Count from QQModel where Id in @id and Count>@count"new { id = new int[] { 1, 2, 3, 4, 5, 6 }, count = 1 });
                foreach (var item in qqModeList)
                {
                    Console.WriteLine(item.Id + " " + item.Name + " " + item.Count);
                }
            }
            #endregion

动态类型:

1
2
3
4
5
6
7
8
9
10
11
12
13
#region 动态类型
            逆天动态类型用的比较多[可能是MVC ViewBag用多了]
            //public static IEnumerable<dynamic> Query (this IDbConnection cnn, string sql, object param = null, SqlTransaction transaction = null, bool buffered = true)
            using (SqlConnection conn = new SqlConnection(connStr))
            {
                conn.Open();
                var qqModeList = conn.Query("select Id,Name,Count from QQModel").ToList();
                foreach (var item in qqModeList)
                {
                    Console.WriteLine(item.Id + " " + item.Name + " " + item.Count);
                }
            }
            #endregion

多映射:

1
2
3
4
5
6
7
8
9
10
11
12
using (SqlConnection conn = new SqlConnection(connStr))
{
    string sqlStr = @"select A.Id,A.Title,S.SeoKeywords from Article A
                    inner join SeoTKD S on A.SeoId=S.Id
                    where A.Id in @ids";
    conn.Open();
    var articleList = conn.Query(sqlStr, new { ids = new int[] { 41, 42, 43, 44, 45, 46, 47, 48 } });
    foreach (var item in articleList)
    {
        Console.WriteLine(item.Id + " | " + item.SeoKeywords + " | :" + item.Title);
    }
}

 多返回值:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
using (SqlConnection conn = new SqlConnection(connStr))
{
    string sqlStr = @"select Id,Title,Author from Article where Id = @id
                      select * from QQModel where Name = @name
                      select * from SeoTKD where Status = @status";
    conn.Open();
    using (var multi = conn.QueryMultiple(sqlStr, new { id = 11, name = "打代码", status = 99 }))
    {
        //multi.IsConsumed   reader的状态 ,true 是已经释放
        if (!multi.IsConsumed)
        {
            //注意一个东西,Read获取的时候必须是按照上面返回表的顺序 (article,qqmodel,seotkd)
            //强类型
            var articleList = multi.Read<Temp>();//类不见得一定得和表名相同
            var QQModelList = multi.Read<QQModel>();
            var SeoTKDList = multi.Read<SeoTKD>();
            //动态类型
            //var articleList = multi.Read();
            //var QQModelList = multi.Read();
            //var SeoTKDList = multi.Read();
            #region 输出
            foreach (var item in QQModelList)
            {
                Console.WriteLine(item.Id + " " + item.Name + " " + item.Count);
            }
            foreach (var item in SeoTKDList)
            {
                Console.WriteLine(item.Id + " | " + item.SeoKeywords);
            }
            foreach (var item in articleList)
            {
                Console.WriteLine(item.Author);
            }
            #endregion
        }
    }
}

 增删改查:(删项目里面基本上不用)

1
2
3
4
5
6
7
8
9
10
11
12
13
using (SqlConnection conn = new SqlConnection(connStr))
{
    conn.Open();
    //增
    int count = conn.Execute("insert into Article values(@title,@content,@author,961,1,2,2,N'2015-11-23 11:06:36.553',N'2015-11-23 11:06:36.553',N'5,103,113',91,N'3,5,11',0,N'/Images/article/16.jpg')"new { title = "Title1", content = "TContent1", author = "毒逆天" });
    //改
    //int count = conn.Execute("update Article set Title=@title where Id=@id", new { title = "么么哒", id = 274 });
    if (count > 0)
    {
        Console.WriteLine(count + "条操作成功");
    }
}

存储过程:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
//查询
using (SqlConnection conn = new SqlConnection(connStr))
{
    conn.Open();
    //参数名得和存储过程的变量名相同(参数可以跳跃传,键值对方式即可)
    //动态类型
    //var list = conn.Query("usp_test", new { aId = 11 }, commandType: CommandType.StoredProcedure);
    //强类型
    var list = conn.Query<TitleAndKeyWords>("usp_test"new { aId = 11 }, commandType: CommandType.StoredProcedure);
    foreach (var item in list)
    {
        Console.WriteLine(item.Id + " | " + item.SeoKeywords + " | :" + item.Title);
    }
}
//插入
using (SqlConnection conn = new SqlConnection(connStr))
{
    conn.Open();
    int count = conn.Execute("usp_insertArticle"new { title = "Title11", content = "TContent1", author = "毒逆天" }, commandType: CommandType.StoredProcedure);
    if (count > 0)
    {
        Console.WriteLine(count + "条操作成功");
    }
}
//更新
using (SqlConnection conn = new SqlConnection(connStr))
{
    conn.Open();
    int count = conn.Execute("usp_updateArticle"new { id = 276, title = "Dapper使用" }, commandType: CommandType.StoredProcedure);
    if (count > 0)
    {
        Console.WriteLine(count + "条操作成功");
    }
}

事物的使用:

先看看ADO.Net怎么用的

            using (SqlConnection conn = new SqlConnection(connStr)){string sql = @"insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 1) insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 1) insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 1) insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 999999999999999999999999) insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 1) insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 1) ";using (SqlCommand cmd = new SqlCommand(sql, conn)){conn.Open();cmd.Transaction = conn.BeginTransaction();try{int i = cmd.ExecuteNonQuery();
cmd.Transaction.Commit();Console.WriteLine(i);}catch (Exception ex){cmd.Transaction.Rollback();Console.WriteLine(ex);}}}

再看看Dapper的

using (SqlConnection conn = new SqlConnection(connStr)){string sql = @"insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 1) insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 1) insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 1) insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 9999999999999999999) insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 1) insert into SeoTKD values(N'毒逆天,测试', N'测试测试测试', 1) ";conn.Open();var transaction = conn.BeginTransaction();try{int i = conn.Execute(sql, transaction: transaction);transaction.Commit();Console.WriteLine(i);}catch (Exception ex){transaction.Rollback();Console.WriteLine(ex);}}

本文转自毒逆天博客园博客,原文链接:http://www.cnblogs.com/dunitian/p/5226265.html,如需转载请自行联系原作者

Dapper逆天入门~强类型,动态类型,多映射,多返回值,增删改查+存储过程+事物案例演示...相关推荐

  1. JDBC从入门到熟练使用——功能类详解、增删改查(CRUD)、sql注入、事务、连接池

    一.JDBC入门 1.jdbc的概念 JDBC(Java DataBase Connectivity:java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系型数据库提供统一访问 ...

  2. 【机器学习入门笔记11:numpy模块实现矩阵的增删改查】20190217

    2019-02-17  by 崔斐然 除了TensorFlow设置的矩阵之外,我们还可以通过numpy模块使用矩阵. 我们先在anaconda中参考笔记1中的配置方法安装numpy. 下面我们通过nu ...

  3. Vue 脚手架结合 SpringBoot 构建前后端分离入门项目(实现增删改查)

    Vue 脚手架构建前后端分离项目 项目简介与预览 数据库建表 主要模块代码 index.js 路由代码 User.vue 用户组件 RAP2 创建接口进行测试 切换路由组件的显示: this.$rou ...

  4. JDBC+MySQL入门增删改查案例

    目录 前言 案例分析 核心思路拆解 案例涉及知识点 第一关 创建数据库和项目 创建数据库 创建项目 第二关 JDBC插入和查询 预备工作 单个插入 批量插入 查询数据 JDBC修改和删除 修改数据 删 ...

  5. Mybatis实现增删改查 -- Mybatis快速入门保姆级教程(二)

    文章目录 前言 五.配置文件完成增删改查 1.学习目标 2.入门案例环境准备 3.查询--查询所有 4.查询--根据id查询 5. 查询--条件查询 6.查询--多条件动态查询 7.条件查询--单条件 ...

  6. mybatis教程--实现增删改查的入门教程

    1 开发环境 jdk1.7.0_72 eclipse:eclipse-3.7-indigo mysql:mysql5.1 1.1 创建数据库 先导入sql_table.sql,再导入sql_data. ...

  7. xml gridview控件增删改查_Mybatis之XML如何映射到方法

    前言 上文Mybatis之方法如何映射到XML中介绍了Mybatis是如何将方法进行分拆出方法名映射到statementID,参数如何解析成xml中sql所需要的,以及返回类型的处理:本文将从XML端 ...

  8. ABP入门系列(5)——展现层实现增删改查

    ABP入门系列目录--学习Abp框架之实操演练 源码路径:Github-LearningMpaAbp 这一章节将通过完善Controller.View.ViewModel,来实现展现层的增删改查.最终 ...

  9. 02.Mybatis的动态代理方式实现增删改查

    动态代理的方式实现增删改查: 通过约定的方式定位sql语句 约定 > 配置文件 > 硬编码 约定的目标是省略掉通过硬编码的方式定位sql的代码,通过接口直接定位出sql语句,以下代码为通过 ...

最新文章

  1. PHP下载/采集远程图片到本地
  2. Linux 小知识翻译 - 「端口限制」
  3. 健康管理-健康的概念和健康管理目标特点
  4. 03-list,set,数据结构,Collections
  5. CVPR | 旷视提出Meta-SR:单一模型实现超分辨率任意缩放因子
  6. 诺基亚:Symbian 3操作系统拥有多点触控功能
  7. apache virtualhost 访问不了_六星教育:你为什么当不了架构师?除技术,你还需具备这些能力...
  8. 猿编程python代码_猿编程怎么练习编程 让你提前熟悉代码
  9. Matlab 学习入门 图像处理
  10. 留学Assignment写作要注意逻辑谬误
  11. 21、随机调整锐度 transforms.RandomAdjustSharpness()
  12. java 正则校验经纬度格式
  13. java fifo lifo_一日一技:Python队列:FIFO 和 LIFO
  14. 电池续航时间增10倍
  15. 跟它比,期货简直 Low 爆了!
  16. Titan图形数据库的应用实例讲解
  17. 最新『资源分享』IT视频教程
  18. 【运动控制】运动控制类实现
  19. 数据治理和数据安全治理有何不同?
  20. loopback回环接口

热门文章

  1. 剑指offer:26-30记录
  2. 关于游戏排行榜设计开发的一些总结
  3. 游戏服务器架构-设计模式之观察者模式和发布订阅模式真的一样吗?
  4. 大数据学习(2-2)- 使用docker安装配置Hadoop环境
  5. 《Java8实战》笔记(07):并行数据处理与性能
  6. C++标准库 第七章 STL迭代器
  7. 王道考研 计算机网络5 分层结构 协议 服务 接口
  8. 一个通用的makefile写法,自动推导文件的依赖关系
  9. 日本专家给出的存钱高招(图)
  10. Tiny Core Linux 4.5 发布,微型 Linux 操作系统