zoukankan      html  css  js  c++  java
  • MyDAL

    索引:

    目录索引

    一.API 列表

      .QueryOneAsync() 

      .QueryOneAsync<M>()

        如: .QueryOneAsync<Agent>() , 用于 单表/多表连接 查询.

      .QueryOneAsync<VM>()

        如: .QueryOneAsync<AgentVM>() , 用于 单表 查询.

      .QueryOneAsync<T>(Expression<Func<M, T>> columnMapFunc)

        如: .QueryOneAsync<Guid>(it => it.Id) , 用于 单表 单列 查询.

        或者:

            .QueryOneAsync<AgentVM>(it => new AgentVM
                       {
                          XXXX = it.Name,
                          YYYY = it.PathId
                       })    , 用于 单表 多列 查询.

      .QueryOneAsync<T>(Expression<Func<T>> columnMapFunc)

        如: .Queryer(out Agent agent, out AgentInventoryRecord agentRecord)

          ......

          .QueryOneAsync<string>(() => agent.Name)

          用于 多表连接 单列 查询.

        或者:

          .Queryer(out Agent agent2, out AgentInventoryRecord record2)

          ......

          .QueryOneAsync(() => new AgentVM
                       {
                          nn = agent2.PathId,
                          yy = record2.Id,
                          xx = agent2.Id,
                          zz = agent2.Name,
                          mm = record2.LockedCount
                         })  , 用于 多表连接 多列 查询.

    二.API 单表-便捷 方法 举例

      1. 单表 单列 便捷方法    

    1             var pk = Guid.Parse("8f2cbb64-8356-4482-88ee-016558c05b2d");
    2             var date= DateTime.Parse("2018-08-20 19:12:05.933786");
    3 
    4             var res3 = await Conn
    5          .QueryOneAsync<AlipayPaymentRecord, Guid>(it => it.Id == pk && it.CreatedOn == date,it=>it.Id);

        以 MySQL 为例,生成 SQL 如下:

    1 select `Id`
    2 from `AlipayPaymentRecord`
    3 where ( `Id`=?Id_2 &&  `CreatedOn`=?CreatedOn_3)
    4 limit 0,1;

      2. 单表 多列 便捷方法

     1             var pk = Guid.Parse("8f2cbb64-8356-4482-88ee-016558c05b2d");
     2             var date= DateTime.Parse("2018-08-20 19:12:05.933786");
     3 
     4             var res4 = await Conn
               .QueryOneAsync<AlipayPaymentRecord, AlipayPaymentRecordVM>(it => it.Id == pk && it.CreatedOn == date, 5 it => new AlipayPaymentRecordVM 6 { 7 Id = it.Id, 8 TotalAmount = it.TotalAmount, 9 Description = it.Description 10 });

        以 MySQL 为例,生成 SQL 如下:

    1 select     `Id` as Id,
    2     `TotalAmount` as TotalAmount,
    3     `Description` as Description
    4 from `AlipayPaymentRecord`
    5 where ( `Id`=?Id_2 &&  `CreatedOn`=?CreatedOn_3)
    6 limit 0,1;

      3. 单表 单条 VM 便捷方法

    1             var pk = Guid.Parse("8f2cbb64-8356-4482-88ee-016558c05b2d");
    2             var date = DateTime.Parse("2018-08-20 19:12:05.933786");
    3 
    4             var res5 = await Conn
    5          .QueryOneAsync<AlipayPaymentRecord, AlipayPaymentRecordVM>(it => it.Id == pk && it.CreatedOn == date);

        以 MySQL 为例,生成 SQL 如下:

    1 select     `Id`,
    2     `CreatedOn`,
    3     `TotalAmount`,
    4     `Description`,
    5     `CanceledOn`
    6 from `AlipayPaymentRecord`
    7 where ( `Id`=?Id_2 &&  `CreatedOn`=?CreatedOn_3)
    8 limit 0,1;

      4. 单表 单条 M 便捷方法

    1             var pk = Guid.Parse("8f2cbb64-8356-4482-88ee-016558c05b2d");
    2             var date = DateTime.Parse("2018-08-20 19:12:05.933786");
    3 
    4             var res6 = await Conn
    5          .QueryOneAsync<AlipayPaymentRecord>(it => it.Id == pk && it.CreatedOn == date);

        以 MySQL 为例,生成 SQL 如下:

    1 select *
    2 from `AlipayPaymentRecord`
    3 where ( `Id`=?Id_2 &&  `CreatedOn`=?CreatedOn_3)
    4 limit 0,1;

    三.API 单表-完整 方法 举例

      1. 单表 单列 完整方法

    1             var time1 = DateTime.Parse("2018-08-16 19:22:01.716307");
    2 
    3             var res1 = await Conn
    4                 .Queryer<Agent>()
    5                 .Where(it => it.CreatedOn == time1)
    6                 .QueryOneAsync<Guid>(it => it.Id);

        以 MySQL 为例,生成 SQL 如下:

    1 select `Id`
    2 from `Agent`
    3 where  `CreatedOn`=?CreatedOn_1
    4 limit 0,1;

       2.单表 多列 完整方法

    1             var res3 = await Conn
    2                 .Queryer<Agent>()
    3                 .Where(it => it.Id == Guid.Parse("000c1569-a6f7-4140-89a7-0165443b5a4b"))
    4                 .QueryOneAsync<AgentVM>(it => new AgentVM
    5                 {
    6                     XXXX = it.Name,
    7                     YYYY = it.PathId
    8                 });

        以 MySQL 为例,生成 SQL 如下:

    1 select     `Name` as XXXX,
    2     `PathId` as YYYY
    3 from `Agent`
    4 where  `Id`=?Id_1
    5 limit 0,1;

      3.单表 单条 VM 完整方法

    1             var res1 = await Conn
    2                 .Queryer<Agent>()
    3                 .Where(it => it.Id == Guid.Parse("000c1569-a6f7-4140-89a7-0165443b5a4b"))
    4                 .QueryOneAsync<AgentVM>();

        以 MySQL 为例,生成 SQL 如下:

     1 select     `Id`,
     2     `CreatedOn`,
     3     `UserId`,
     4     `PathId`,
     5     `Name`,
     6     `Phone`
     7 from `Agent`
     8 where  `Id`=?Id_1
     9 limit 0,1;

      4.单表 单条 M 完整方法

    1             var res1 = await Conn
    2                 .Queryer<BodyFitRecord>()
    3                 .Where(it => it.Id == Guid.Parse("1fbd8a41-c75b-45c0-9186-016544284e2e"))
    4                 .QueryOneAsync();

        以 MySQL 为例,生成 SQL 如下:

    1 select *
    2 from `BodyFitRecord`
    3 where  `Id`=?Id_1
    4 limit 0,1;

    四.API 多表连接-完整 方法 举例

      1.多表连接 单列 完整方法

    1             var res1 = await Conn
    2                 .Queryer(out Agent agent, out AgentInventoryRecord agentRecord)
    3                 .From(() => agent)
    4                     .InnerJoin(() => agentRecord)
    5                         .On(() => agent.Id == agentRecord.AgentId)
    6                 .Where(() => agent.AgentLevel == AgentLevel.DistiAgent)
    7                 .QueryOneAsync<string>(() => agent.Name);

        以 MySQL 为例,生成 SQL 如下:

    1 select agent.`Name`
    2 from `Agent` as agent 
    3     inner join AgentInventoryRecord as agentRecord
    4         on agent.`Id`=agentRecord.`AgentId`
    5 where  agent.`AgentLevel`=?AgentLevel_4
    6 limit 0,1;

      2.多表连接 多列 完整方法

     1             var guid2 = Guid.Parse("544b9053-322e-4857-89a0-0165443dcbef");
     2 
     3             var res2 = await Conn
     4                 .Queryer(out Agent agent2, out AgentInventoryRecord record2)
     5                 .From(() => agent2)
     6                     .InnerJoin(() => record2)
     7                         .On(() => agent2.Id == record2.AgentId)
     8                 .Where(() => agent2.Id == guid2)
     9                 .QueryOneAsync(() => new AgentVM
    10                 {
    11                     nn = agent2.PathId,
    12                     yy = record2.Id,
    13                     xx = agent2.Id,
    14                     zz = agent2.Name,
    15                     mm = record2.LockedCount
    16                 });

        以 MySQL 为例,生成 SQL 如下:

     1 select     agent2.`PathId` as nn,
     2     record2.`Id` as yy,
     3     agent2.`Id` as xx,
     4     agent2.`Name` as zz,
     5     record2.`LockedCount` as mm
     6 from `Agent` as agent2 
     7     inner join AgentInventoryRecord as record2
     8         on agent2.`Id`=record2.`AgentId`
     9 where  agent2.`Id`=?Id_4
    10 limit 0,1;

      3.多表连接 单条 M 完整方法

    1             var guid6 = Guid.Parse("544b9053-322e-4857-89a0-0165443dcbef");
    2 
    3             var res6 = await Conn
    4                 .Queryer(out Agent agent6, out AgentInventoryRecord record6)
    5                 .From(() => agent6)
    6                     .InnerJoin(() => record6)
    7                         .On(() => agent6.Id == record6.AgentId)
    8                 .Where(() => agent6.Id == guid6)
    9                 .QueryOneAsync<Agent>();

        以 MySQL 为例,生成 SQL 如下:

    1 select agent6.`*`
    2 from `Agent` as agent6 
    3     inner join AgentInventoryRecord as record6
    4         on agent6.`Id`=record6.`AgentId`
    5 where  agent6.`Id`=?Id_4
    6 limit 0,1;

                                             蒙

                                        2018-12-13 14:35 周四

                                        2018-12-30 11:25 周日

                                        2019-02-24 17:03 周日

                                        2019-04-12 19:32 周五

  • 相关阅读:
    【CodeForces】[366A]Dima and Guards
    Linux将程序前台转后台执行
    Storm在Mesos上跑与不在的运行命令区别
    去掉SSH KEY密码
    git 退回到倒数第二次提交
    浅析UGC、PGC和OGC
    linux主机名与IP地址配置文件
    wget ERROR 404: Not Found.
    cpuacct (CPU Accounting Controller)
    Ansible的安装与使用
  • 原文地址:https://www.cnblogs.com/Meng-NET/p/10113980.html
Copyright © 2011-2022 走看看