一、SqlRepoEx引用

暂时没放至nuget上,可以直接到https://github.com/AzThinker/SqlRepoEx下载源码,编译引用。

(一)、静态引用

1、需引用以下dll在\SqlRepoEx\SqlRepo.SqlServer.Static\bin\Debug\netstandard2.0目录下:

(1)、SqlRepoEx.dll;

(2)、SqlRepoEx.SqlServer.dll;

(3)、SqlRepoEx.SqlServer.Static.dll;

2、初始化SqlRepoEx工厂类

var connectionProvider = new AppConfigFirstConnectionProvider();

RepoFactory.UseConnectionProvider(connectionProvider);

RepoFactory.UseLogger(new NoOpSqlLogger())

以上为一个简单初始方式

(1)、AppConfigFirstConnectionProvider是一个简单的配置管理实现,如果需自定义自己的连接提供者,实现ISqlConnectionProvider接口即可,SqlRepoEx中SqlRepoEx.SqlServer.ConnectionProviders实现了四个标准数据库连接管理器。

(2)、使用RepoFactory的静态方法注册配置提供者,RepoFactory.UseConnectionProvider(connectionProvider);

(3)、注册一个日志器(必需注册一个);

二、使用Autofac注入方式

1、需引用以下dll

在\SqlRepoEx\SqlRepo.SqlServer.Autofac\bin\Debug\netstandard2.0目录下:

(1)、SqlRepoEx.dll;

(2)、SqlRepoEx.SqlServer.dll;

(3)、SqlRepoEx.SqlServer.Autofac.dll;

2、Autofac容器构建

var containerBuilder = new ContainerBuilder();

containerBuilder.RegisterModule<SqlRepoSqlServerAutofacModule>();

var connectionProvider = new AppConfigFirstConnectionProvider();

containerBuilder.RegisterInstance(connectionProvider)

.As<IConnectionProvider>();

// ... 其他类型注册

var container = containerBuilder.Build();

三、服务注册

1、需引用以下dll

在\SqlRepoEx\SqlRepo.SqlServer.ServiceCollection\bin\Debug\netstandard2.0目录下:

(1)、SqlRepoEx.dll;

(2)、SqlRepoEx.SqlServer.dll;

(3)、SqlRepoEx.SqlServer.ServiceCollection.dll;

2、以下是在Asp.Core中初始方式

public void ConfigureServices(IServiceCollection services)

{

...

services.AddSqlRepo();

services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);

}

四、资源工厂调用

以下为一简单使用

1、定义一个简单类

public class ToDo : Entity<int>

{

public DateTime CreatedDate { get; set; }

public bool IsCompleted { get; set; }

public string Task { get; set; }

}

(1)、在SqlRepoEx不必从Entity<int>中继承,如果你使用SqlRepo则是必需的;

(2)、声明的类型不必依赖于数据库,这点与EF是有很大区别的;

2、调用

var repository = RepoFactory.Create<ToDo>();

var results = repository.Query()

.Select(e => e.Id, e => e.Task, e => e.CreatedDate)

.Where(e => e.IsCompleted == false)

.Go();

foreach (var row in results)

{

Console.WriteLine($"{row.Id},{row.Task},{row.IsCompleted},{row.CreatedDate}");

}

(1)、使用RepoFactory的静态方法,创建一个Repository;

(2)、根据需求,通过Repository进行业务操作

轻量ORM-SqlRepoEx (二)初始化SqlRepoEx的更多相关文章

  1. 轻量ORM-SqlRepoEx (十)SqlRepoEx Nuget包下载说明

    ORM-SqlRepoEx 是 .Net平台下兼容.NET Standard 2.0,一个实现以Lambda表达式转转换标准SQL语句,使用强类型操作数据的轻量级ORM工具,在减少魔法字串同时,通过灵 ...

  2. SqlSugar轻量ORM

      蓝灯软件数据股份有限公司项目,代码开源. SqlSugar是一款轻量级的MSSQL ORM ,除了具有媲美ADO的性能外还具有和EF相似简单易用的语法. 学习列表 0.功能更新 1.SqlSuga ...

  3. Dapper.NET——轻量ORM

    Dapper.NET使用 http://www.cnblogs.com/yankliu-vip/p/4182892.html 本文目录 Dapper.NET使用 1.为什么选择Dapper 2.以Da ...

  4. Dapper.NET—轻量ORM

    Dapper.NET使用 本文目录 Dapper.NET使用 1.为什么选择Dapper 2.以Dapper(4.0)为例. 2.1 在数据库中建立几张表. 2.2实体类. 3.使用方法 3.1  一 ...

  5. 轻量ORM-SqlRepoEx (十七)SqlRepoEx 2.30 版本更新说明

    .Net平台下兼容.NET Standard 2.0,一个实现以Lambda表达式转转换标准SQL语句,支持MySQL.SQL Server数据库方言,使用强类型操作数据的轻量级ORM工具,在减少魔法 ...

  6. 轻量ORM-SqlRepoEx (一)SqlRepoEx介绍

    一.SqlRepo项目 发现SqlRepo项目库是在构建自动代码工具时.对于数据访问,在.Net下,有很多选择,比如EF,但EF使用起来,不是很方便的.以前一直使用Atk.Expression库+Sy ...

  7. C# Dapper 轻量ORM调试对SQLServer

    Dapper简介 Dapper只有一个代码文件,完全开源,你可以放在项目里的任何位置,来实现数据到对象的ORM操作,体积小速度快. 使用ORM的好处是增.删.改很快,不用自己写sql,因为这都是重复技 ...

  8. PL/SQL轻量版(二)——基本语法

    一.流程控制 1.条件判断 语法: IF <布尔表达式> THEN PL/SQL 和 SQL语句 END IF; IF <布尔表达式> THEN PL/SQL 和 SQL语句 ...

  9. 轻量ORM-SqlRepoEx介绍

    轻量级 ORM-SqlRepoEx 介绍 SqlRepoEx是 .Net平台下兼容.NET Standard 2.0人一个轻型的ORM.解决了Lambda转Sql语句这一难题,SqlRepoEx使用的 ...

随机推荐

  1. 4、Angular2 pipe

    1. stateless pipe 2.stateful pipe

  2. goto语句和标签

    goto 语句用于将执行流更改到标签处,虽然t-sql和pl/sql都提供了该语句,但是作为编程而言,我们不推荐使用此编程技术.要编写一个标签,应当在标识符后面加一个冒号.列如,下面示例使用goto语 ...

  3. ACM-线段树扫描线总结

    扫描线的基础概念可以看这几篇文章 http://blog.csdn.net/xingyeyongheng/article/details/8927732 http://www.cnblogs.com/ ...

  4. STL库中string类内存布局的探究

    在STL中有着一个类就是string类,他的内存布局和存储机制究竟是怎么样的呢? 这就是建立好的string 可以看出,图中用黄色框框标注的部分就是主要区域 我们用来给string对象进行初始化的字符 ...

  5. OLEDB 静态绑定和数据转化接口

    OLEDB 提供了静态绑定和动态绑定两种方式,相比动态绑定来说,静态绑定在使用上更加简单,而在灵活性上不如动态绑定,动态绑定在前面已经介绍过了,本文主要介绍OLEDB中的静态,以及常用的数据类型转化接 ...

  6. html5 嵌入元素 img map areaiframe embed meter object meter

    <img src="路径">            src 路径可以是img.jpg 也可以是 绝对和相对路径+img.jpg <img src="路径 ...

  7. 沙箱模式的chrome浏览器的运行

    getUserMedia在chrome 47后已经不可以从非安全源访问(Insecure Origins),但测试搭建apprtc时服务器一般没有添加HTTPS安全验证,chrome就没有权限访问麦克 ...

  8. OPENCV VS设置

    OPENCV VS设置 第一步 工程->工具->选项->VC++目录 第二步 这两项放到系统path下 D:\OpenCV2.4.3\VS\bin\Debug;D:\OpenCV2. ...

  9. ArcEngine开发鹰眼实现问题

    在网上百度一下有关AE鹰眼实现的代码,基本是一样的,可问题是好多代码自己运行起来鹰眼却总是加不进地图.住视图axMapControl1.OnMapReplaced(),axMapControl1.On ...

  10. ViewPager+handler实现轮播

    先说下功能吧,随便设置一个网络图片链接的集合,作为图片的资源.我用ImageLoader来加载图片,在图片未加载完成时会ProgressBar加载状态 在Handler发送一个空消息来实现页面的轮播 ...