授权协议: MIT
开发语言: C#
操作系统: 跨平台
收录时间: 2019-02-14
提 交 者: rainrcn

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

功能特点:

  • 支持 DoNet Core 2.0+ && DotNet Framework 4.6.1+

  • 支持依赖注入系统

  • MyBatis sql xml 语法

  • 多数据库支持

  • 灵活扩展性

  • 使用简单

基本用法:

添加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
        }
    }
    展开阅读全文

    代码

    的 Gitee 指数为
    超过 的项目

    Insql 的相关博客

    轻量级.NET CORE ORM框架Insql使用教程

    Insql 国人开发,是一款汲取 Mybatis 优点的.NET ORM 框架。追求简单直观,使用自由灵活等特点。 项目主页:https://rainrcn...

    mp条件构造器(1)

    条件构造器(1) 抽象类AbstractWrapper 定义了一些构造条件的方法,在使用的使用我们使用他的子类QueryWrapper 实例化后构造...

    Spring 框架基础(05):事务管理机制,和实现方式

    本文源码:GitHub·点这里 || GitEE·点这里 一、Spring事务管理 1、基础描述 Spring事务管理的本质就是封装了数据库对事务支...

    springboot项目mybatisplus的快速使用

    一 、MyBatisPlus 介绍 转自mybatisplus官网 下方附有mybatisplus官方网站 MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具...

    基础开发之Mybatis Plus基础使用

    Mybatis-Plus 是一款 Mybatis 动态 SQL 自动注入 Mybatis 增删改查 CRUD 操作中间件, 减少你的开发周期优化动态维护 XML 实体...

    mybatis-plus 从2.x到3.x升级指南

    mybatis-plus 2.x 到 3.x 有以下改进 分页查询可以直接返回Ipage<T>的子类(下面会有详细使用说明) Wrapper<T>实现类的改动 1....

    MyBatis-Plus使用(3)-条件构造器

    说明:   以下出现的第一个入参boolean condition表示该条件是否加入最后生成的sql中   以下代码块内的多个方法均为从上往...

    MyBatis-Plus(概述、快速入门、日志配置、主键生成策略、自动填充、CRUD、性能分析插件、条件构造器、代码生成器)

    文章目录 MyBatis-Plus (一)概述 (二)快速入门 1. 创建数据库和表 2. 创建SpringBoot项目导入项目依赖 3. 配置 applicat...

    mybatis-plus 2.x升级3.x注意点

    2.0到3.0主要升级的点: 升级 JDK 8 + 优化性能 Wrapper 支持 lambda 语法 模块化 MP 合理的分配各个包结构 重构注入方法,支...

    Insql 的相关问答

    还没有任何问答,马上提问

    评论 (5)

    加载中
    关于mybatis产生动态sql,个人觉得mybatis不太灵活,不知道你是不是复制mybatis产生sql的那套机制,其实C#的强大功能完全可以有更好的实现方式,如果你有兴趣,欢迎回复共同讨论下。 mybatis已经实现mybatis plus,对于基本的crud,mybatis已经封装了
    2019/06/23 22:37
    回复
    举报
    rainrcn软件作者

    引用来自“crystalsis”的评论

    java那边的人在拼命的摆脱xml,c#这边还在往xml上靠

    引用来自“rainrcn”的评论

    哈哈,应该是没有完美的东西吧。什么东西用久了也会因为其中的不爽厌烦。我原本是开发C#的。数据库访问这块必然是追求简洁直接,灵活与性能。从JAVA那边转了一圈后。发现Mybatis这东西很是不错的。由此就有了Insql 😄

    引用来自“周杰伦的小迷弟”的评论

    mvc不能用?
    2019/05/17 14:07
    回复
    举报

    引用来自“crystalsis”的评论

    java那边的人在拼命的摆脱xml,c#这边还在往xml上靠

    引用来自“rainrcn”的评论

    哈哈,应该是没有完美的东西吧。什么东西用久了也会因为其中的不爽厌烦。我原本是开发C#的。数据库访问这块必然是追求简洁直接,灵活与性能。从JAVA那边转了一圈后。发现Mybatis这东西很是不错的。由此就有了Insql 😄
    mvc不能用?
    2019/05/09 14:27
    回复
    举报
    rainrcn软件作者

    引用来自“crystalsis”的评论

    java那边的人在拼命的摆脱xml,c#这边还在往xml上靠
    哈哈,应该是没有完美的东西吧。什么东西用久了也会因为其中的不爽厌烦。我原本是开发C#的。数据库访问这块必然是追求简洁直接,灵活与性能。从JAVA那边转了一圈后。发现Mybatis这东西很是不错的。由此就有了Insql 😄
    2019/02/20 16:59
    回复
    举报
    java那边的人在拼命的摆脱xml,c#这边还在往xml上靠
    2019/02/20 16:26
    回复
    举报
    更多评论
    5 评论
    16 收藏
    分享
    在线直播报名
    返回顶部
    顶部