Insql 1.2.5 发布,轻量级.NET ORM,数据库访问利器

栏目: ASP.NET · 发布时间: 5年前

内容简介:以上配置生成后,会在选择目录中生成Context\BookDbContext.cs,BookDbContext.insql.xml,Model\BookPo.cs,BookCategoryPo.cs

轻量级的.NET ORM类库 . 对象映射基于Dapper , Sql配置灵感来自于Mybatis.

1.2.5版更新内容:

  • 添加CodeSmith代码生成器文件

  • 支持同一Insql Type类型的多个insql.xml文件合并,用于方便配置多数据库Sql

  • 添加each配置元素,用以支持select in list 多参数功能

  • 优化SqlResolve的跨数据库匹配功能

  • 优化DbContext,DbSession的配置和创建过程,减少内存分配和加快初始化时间

CodeSmith代码生成器:

Insql 1.2.5 发布,轻量级.NET ORM,数据库访问利器

以上配置生成后,会在选择目录中生成Context\BookDbContext.cs,BookDbContext.insql.xml,Model\BookPo.cs,BookCategoryPo.cs

多Insql.xml文件合并:

Insql 1.2.5 发布,轻量级.NET ORM,数据库访问利器

Insql 1.2.5 发布,轻量级.NET ORM,数据库访问利器

insql.xml文件随意布局,只需要保证同一DbContext类型的insql type保持一致。

新增each配置元素:

<?xml version="1.0" encoding="utf-8" ?>
<insql type="Insql.Tests.EachSectionElementTests,Insql.Tests" >
  <select id="EachIn">
    select * from user_info where user_id in <each name="userIdList" open="(" separator="," close=")" prefix="@"  />
  </select>

  <select id="EachInNull">
    select * from user_info
    <where>
      <if test="userIdList !=null and userIdList.length >0">
        user_id in <each name="userIdList" open="(" separator="," close=")" prefix="@"  />
      </if>
    </where>
  </select>
</insql>

在Sql Resolve 之后将会被转换为:

select * from user_info where user_id in (@userIdList1,@userIdList2)

类库用法介绍:

1.精简用法:

只将Insql用作加载和解析 Sql 语句来使用。

注入ISqlResolver

在Domain Service中使用语句解析器,将 ISqlResolver<T> 注入到UserService中,其中 T 类型我们指定为 UserService 类型

public class UserService : IUserService
{
  private readonly ISqlResolver<UserService> sqlResolver;

  public UserService(ISqlResolver<UserService> sqlResolver)
  {
      this.sqlResolver = sqlResolver;
  }

  public void DeleteUser(int userId)
  {
      var resolveResult = this.sqlResolver.Resolve("DeleteUser", new { userId });

      //如果需要指定数据库(匹配SqlId后缀为.SqlServer),则需要设置DbType的参数
      //var resolveResult = this.sqlResolver.Resolve("SqlServer", "DeleteUser", new { userId });

      //connection.Execute(resolveResult.Sql,resolveResult.Param) ...
  }
}

创建UserService.insql.xml

创建 UserService.insql.xml ,用作Sql语句配置,insql type 指定为 ISqlResolver<T>T 类型,当然也可以针对每个Model创建。

<insql type="Insql.Tests.Domain.Services.UserService,Insql.Tests" >
  
  <delete id="DeleteUser">
    delete from user_info where user_id = @userId
  </delete>
  
</insql>

添加 Insql

public void ConfigureServices(IServiceCollection services)
{
  services.AddInsql();

  services.AddScoped<IUserService, UserService>();
}

2.基本用法:

基本用法可以通过创建DbContext来使用

添加 Insql

public void ConfigureServices(IServiceCollection services)
{
    services.AddInsql();

    services.AddInsqlDbContext<UserDbContext>(options =>
    {
      //options.UseSqlServer(this.Configuration.GetConnectionString("sqlserver"));
      options.UseSqlite(this.Configuration.GetConnectionString("sqlite"));
    });
}

创建 DbContext

public class UserDbContext : Insql.DbContext  
{
    public UserDbContext(Insql.DbContextOptions<UserDbContext> options) 
		: base(options)
    {
    }

    public IEnumerable<UserInfo> GetUserList(string userName)
    {
        //sqlId = "GetUserList"
        //sqlParam is PlainObject or IDictionary<string,object>
        return this.Query<UserInfo>(nameof(GetUserList), new { userName, userGender = Gender.W });
    }

    public void InsertUser(UserInfo info)
    {
        var userId = this.ExecuteScalar<int>(nameof(InsertUser),info);

        info.UserId = userId;
    }

    public void UpdateUserSelective(UserInfo info)
    {
        this.Execute(nameof(UpdateUserSelective), info);
    }
}
	
//user model
public class UserInfo
{
    public int UserId { get; set; }

    public string UserName { get; set; }

    public Gender? UserGender { get; set; }
}

public enum Gender
{
    M,
    W
}

创建 DbContext.insql.xml

创建  UserDbContext.insql.xml 文件并且修改这个文件的属性为 嵌入式文件 类型 .  insql type 与  UserDbContext 类型对应.

<insql type="Example.Domain.Contexts.UserDbContext,Example.Domain" >
  
    <sql id="selectUserColumns">
      select user_id as UserId,user_name as UserName,user_gender as UserGender from user_info
    </sql>

    <select id="GetUserList">
      <include refid="selectUserColumns" />
      <where>
        <if test="userName != null">
          <bind name="likeUserName" value="'%' + userName + '%'" />
          user_name like @likeUserName
        </if>
        <if test="userGender != null and userGender != 'M' ">
          and user_gender = @userGender
        </if>
      </where>
      order by  user_id
    </select>

    <insert id="InsertUser">
      insert into user_info (user_name,user_gender) values (@UserName,@UserGender);
      select last_insert_rowid() from user_info;
    </insert>

    <update id="UpdateUserSelective">
      update user_info
      <set>
        <if test="UserName != null">
          user_name=@UserName,
        </if>
        <if test="UserGender != null">
          user_gender=@UserGender
        </if>
      </set>
      where user_id = @UserId
    </update>
	
</insql>

使用 DbContext

使用  UserDbContext 在Domain Service中或者Web Controller中

public class ValuesController : ControllerBase
{
    private readonly UserDbContext userDbContext;

    public ValuesController(UserDbContext userDbContext)
    {
        this.userDbContext = userDbContext;
    }

    [HttpGet]
    public ActionResult<IEnumerable<string>> Get()
    {
        //可以这样使用事务
        this.userDbContext.DoWithTransaction(() =>
        {
            var userInfo = new Domain.UserInfo
            {
                UserName = "loveW",
                UserGender = Domain.Gender.M
            };

            this.userDbContext.InsertUser(userInfo);

            this.userDbContext.UpdateUserSelective(new Domain.UserInfo
            {
                UserId = userInfo.UserId,
                UserName = "loveWWW",
            });
        });

        var list = this.userDbContext.GetUserList("love");
	//todo return
    }
}

项目源码地址: 码云 :blush:谢谢支持!!


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

突破之道

突破之道

(美)基思 R. 麦克法兰(Keith R. McFarland) / 江南、江维 / 机械工业出版社 / 2017-4 / 49.00

《从优秀到卓越》前传。 深入调查7000多家公司、1500多名关键管理人员,总结提炼出6大突破式发展策略。 解析创业成功后的公司如何腾飞,以几何速度增长,突破10亿关口。 阐述为什么创始人自己才是企业实现突破的最大障碍。一起来看看 《突破之道》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

随机密码生成器
随机密码生成器

多种字符组合密码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具