导航

目   录:Farseer.net轻量级ORM开源框架 目录

上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置文件

下一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射

前言

  上文讲述了数据库配置使用,搭建好数据库的链接方式了我们知道怎么做了。

  事实上,至今我们仍然还没有讲到代码方面,花了前面这么多篇幅讲解,主要是想由浅入深,不然一上来给大家讲解这讲解那的,听的也一头雾水,反而得不到效果。

  这篇比较重要,因为它是我们在使用Farseer.Net时最基础的类:DbContext(与EntityFramework的DbContext一个概念)

数据库上下文

  从字面上,我们就知道:它是我们程序(业务)与数据库之间的沟通桥梁,在对表(实体类)进行CURD时,需要让实体类知道,我需要访问哪种数据库。

  而数据库上下文,就是告诉我们的实体类,应该对哪个数据库类型进行连接访问。

  在Farsser.Net里,数据库上下文对应的类便是:DbContext,这便是需要我们继承它,然后在这个类里面,封装我们需要的实体类的属性。

构造函数
        /// <summary>
/// 通过数据库配置,连接数据库
/// </summary>
/// <param name="dbIndex">数据库选项</param>
protected DbContext(int dbIndex = ) /// <summary>
/// 通过自定义数据链接符,连接数据库
/// </summary>
/// <param name="connectionString">数据库连接字符串</param>
/// <param name="dbType">数据库类型</param>
/// <param name="commandTimeout">SQL执行超时时间</param>
protected DbContext(string connectionString, DataBaseType dbType = DataBaseType.SqlServer, int commandTimeout = )

  带int dbIndex形参的构造函数,传入的便是DbConfig的配置索引项(假如我们配置了多个数据库的话)。

  形参int dbIndex = 0 的默认设置,我们不需要额外的代码来设置它,除非你需要不同的数据库的配置。或者根据自己的业务需要通过自定义构造来达到运行时不同的数据库访问。

  最后一个构造函数,是在我们不使用DbConfig数据库配置项的情况下,指定连接方式。

  上面我们没有用到Web.Config(或者App.Config)配置项,事实上博主很不喜欢在Web.Config中进行设置自定义的配置项,感觉这会有“侵略”的感觉。

DbContext的派生类

  DbContext<TPo>,事实上这个类仅是多了一个属性:

        /// <summary>
/// 静态实例
/// </summary>
public static TPo Data { get { return new TPo { IsMergeCommand = false }; } }

  它仅仅是让我们不需要实例化using(var db = new DbContext())来调用。

  很多时候,我们仅仅是一个很简单的操作。比如仅一条数据的插入:

// 插入数据
Table.Data.User.Insert(new UserVO() { UserName = "yy" });

  而不需要:

using (var context = new Table())
{
info = new UserVO() { UserName = "xx" };
// 插入数据
context.User.Insert(info, true);
context.SaveChanges();
}
实际项目的上下文

  它继承自DbContext<TPo>的:

     /// <summary>
/// 数据库上下文
/// </summary>
public class Table : DbContext<Table>
{
/// <summary>
/// 默认为0时,可不显示填写这一项,当前只是为了演示
/// </summary>
public Table() : base() { } [Set(Name = "Members_User")]
public TableSet<UserVO> User { get; set; } [Set(Name = "Members_Role")]
public TableSetCache<UserRoleVO> UserRole { get; set; }
[Set(Name = "Members_Orders")]
public TableSet<OrdersVO> Orders { get; set; } [Set(Name = "Members_Orders")]
[SortDelete(Name = "IsDeleteByAt", FieldType = eumSortDeleteType.DateTime, Value = true)]
public TableSet<OrdersVO> OrdersAt { get; set; } [Set(Name = "Members_Orders")]
[SortDelete(Name = "IsDeleteByBool", FieldType = eumSortDeleteType.Bool, Value = true)]
public TableSet<OrdersVO> OrdersBool { get; set; } [Set(Name = "Members_Orders")]
[SortDelete(Name = "IsDeleteByNum", FieldType = eumSortDeleteType.Number, Value = )]
public TableSet<OrdersVO> OrdersNum { get; set; }
}

  TableSet相当于EntityFramework的Set类,这在下一篇中才讲述。

DbContext的属性
        /// <summary>
/// 数据库提供者(不同数据库的特性)
/// </summary>
public AbsDbProvider DbProvider { get; private set; } /// <summary>
/// 数据库操作
/// </summary>
public DbExecutor DataBase { get; private set; } /// <summary>
/// 执行数据库操作
/// </summary>
public ExecuteSql Executeor { get; private set; } /// <summary>
/// 映射关系
/// </summary>
public ContextMap Map { get; private set; }

  DbProvider:数据库提供者,不同的数据库类型都要有对应的实现类,比如有:SqlServerProvider。里面实现不同数据库的一些特性。

  DataBase:是生成SQL之后最终提交到这里进行数据库交互。

  Executeor:通过DataBase执行后返回的object/datatable类型进行泛型转换。它与DataBase的区别是它更区向业务上的数据类型。

  Map:是指数据库上下文的映射信息,包括一些Property的信息。

DbContext的方法
/// <summary>
/// 保存修改
/// IsMergeCommand=true时:只提交一次SQL到数据库
/// </summary>
/// <param name="isOlation">默认启用事务操作</param>
public int SaveChanges(bool isOlation = true)

  根据方法命名,我们就可以联想到它是针对数据进行变更时进行的保存提交。

  注意的是:对数据库的查询是不需要调用这个方法的,仅在对数据进行更新、删除、插入时,才需要调用。

  但是,如果你是使用静态方式,即不需要new DbContext()方式时,也不需要调用SaveChanges的。这是提供的一种便利(语法糖)。

  其带了个参数bool isOlation = true,为true时,会默认以事务的方式提交。如果您不希望这样,可以显示传入false。

  

  通常在对数据库进行多次(一个逻辑里面)数据更新、插入时操作。当然这种方式保存的时候默认是开启事务的(查询不是),您也可以手动调用重截来不开启它:SaveChange(false);

  值得注意的是:仅仅是对数据库的查询操作时,是不支持延迟执行的。换句话说,不需要调用context.SaveChange()方法。

  但如果需要对数据进行更新、插入时,则必须调用。

  但是如果用上文提供的静态方法,不管做何操作,也不需要调用SaveChange()。

  我在重新说明下SaveChange()方法在什么时候使用:

  1. new实例化方式
  2. 需要数据进行更新(Update)、插入(Insert)
总结

  这一篇,大家学会了数据库上下文的代码编写了,虽然篇幅很长,但其实就是那么一回事,简单的不能再简单了。

导航

目   录:Farseer.net轻量级ORM开源框架 目录

上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置文件

下一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射

广告时间

QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net

Farseer.Net是一款ORM框架 + 常用工具 + 扩展集合。

Farseer 寓意:先知、预言家 通常在某些场合时,提供计谋、策略。也希望该框架能给大家提供最大化的便捷。

ORM:其英文全称是:Object(对象) Relational(关系) Mapping(映射)

Farseer.Net的目标是:快速上手、快速开发、简单方便。

 Table.Data.User.Where(o=>o.ID == ).ToEntity();
Table.Data.User.Where(o=>o.ID > ).ToList();
Table.Data.User.Where(o=>o.ID != ).Delete();
Table.Data.User.Where(o=>o.ID != ).AddUp(o=>o.LoginCount, );
Table.Data.User.Where(o=>o.ID == ).Update(new User{ UserName = "newName" });
Table.Data.User.Insert(new User{ UserName = "newName" });

Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库上下文的更多相关文章

  1. Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射 下一篇:Farseer.net轻量级ORM开源 ...

  2. Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程数据操作

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射 下一篇:Farseer.net轻量级ORM ...

  3. Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作 下一篇:Farseer.net轻量级ORM开源 ...

  4. Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作 下一篇:Farseer.net轻量级ORM开源框 ...

  5. Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射 下一篇:Farseer.net轻量级ORM开源框 ...

  6. Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库上下文 下一篇:Farseer.net轻量级ORM开源框 ...

  7. Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置文件

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:新版本说明 下一篇:Farseer.net轻量级ORM开源框架 ...

  8. Farseer.net轻量级ORM开源框架 V1.x 入门篇:新版本说明

    导航 目   录:Farseer.net轻量级ORM开源框架 目录 上一篇:没有了 下一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置 前言 V1.x版本终于到来了.本次 ...

  9. Farseer.net轻量级ORM开源框架 V1.x 教程目录

    本篇教程将以Ver 1.x版本进行详细使用讲解 大家有任何疑问可以加入我们的官方QQ群进行讨论.QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net 整个 ...

随机推荐

  1. CodeChef - CHEFPRAD Chef and Pairs 树形DP

     题意 给你一棵由 N 个节点构成的树 T.节点按照 1 到 N 编号,每个节点要么是白色,要么是黑色.有 Q 组询问,每组询问形如 (s, b).你需要检查是否存在一个连通子图,其大小恰好是 s,并 ...

  2. jquery ui tabs详解(中文)

    1 属性1.11 ajaxOptions,当选项卡加载内容时,添加一个ajax选项.只有ajax时,添加的ajax选项才起作用.默认值为null.上面的例子中,添加了beforeSend和succes ...

  3. What's the difference between HEAD, working tree and index, in Git?

    What's the difference between HEAD, working tree and index, in Git?

  4. GC回收算法--当女友跟你提分手!

    Java语言引入了垃圾回收机制,让C++语言中令人头疼的内存管理问题迎刃而解,使得我们Java狗每天开开心心地创建对象而不用管对象死活,这些都是Java的垃圾回收机制带来的好处.但是Java的垃圾回收 ...

  5. sqlite支持linq

    A small library to easily access SQLite databases from .NET/Mono/MonoTouch applications In order to ...

  6. charCode 表示空格 实现中文对齐

    字符以及HTML实体 描述以及说明     这是我们使用最多的空格,也就是按下space键产生的空格.在HTML中,如果你用空格键产生此空格,空格是不会累加的(只算1个).要使用html实体表示才可累 ...

  7. 三步升级已安装的 Android SDK 和 ADT 插件(转载)

    转载:http://www.tfan.org/update-adt-and-android-sdk-in-five-minutes/ 如何快速地把已安装的 Android SDK 及 Eclipse ...

  8. 利用jenv安装maven, tomcat,zookeeper等

    jenv有关的网站: http://jenv.io https://github.com/gcuisinier/jenv 1.  执行jenv安装 $ curl -L -s get.jenv.io | ...

  9. bat批处理文件夹内文件名的提取

    有时候会在做某些东西的时候 我们要提取某个文件夹的所有文件名,一个一个打出来那不是 现实的 所以这个时候就用到了一个比较简便而又快捷的方法 在所在的文件夹内新建一个a.txt 在a.txt编辑DIR ...

  10. 把pdf传给kindle

    对于不是纯文本的,最好主题不要用convert,虽说用了之后可以转换为大小更合适的字体,但是会破坏本来PDF的格式,变得更加不合适阅读