Farseer.net轻量级开源框架 入门篇:添加数据详解

导航

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

上一篇:Farseer.net轻量级开源框架 入门篇: 分类逻辑层数据库

下一篇:Farseer.net轻量级开源框架 入门篇: 修改数据详解app

前面讲的大多数是原理及说明,你们在理解上会比较枯燥,接下来的几篇,倾向于实战,会比较有意思些。框架

 这里的话,仍是拿Users实体类来说解在咱们框架的几种添加方式。ide

Insert的几种方式
1         Users info = new Users();
2         info.UserName = "张三";
3         Users.Data.Insert(info);
1         new Users() { UserName = "张三" }.Insert();

两种方式均可以实现对数据的添加操做。工具

第二种方式实际也是执行第一种的过程。只不过是作了扩展方法。spa

Insert的重载版本
 1         /// <summary>
 2         ///     插入数据
 3         /// </summary>
 4         /// <param name="info">已赋值的实体</param>
 5         /// <param name="db">可传入事务的db</param>
 6         public bool Insert(TInfo info, DbExecutor db = null);
 7 
 8         /// <summary>
 9         ///     插入数据
10         /// </summary>
11         /// <param name="info">已赋值的实体</param>
12         /// <param name="db">可传入事务的db</param>
13         /// <param name="identity">标识,刚插入的ID</param>
14         public bool Insert(TInfo info, out int identity, DbExecutor db = null);

上面演示的,实质上是第一个方法。而第二个方法。多了一个参数:out int identity.net

将在插入数据库时,把自增ID返回到这个参数来。code

须要注意的是:实际上第一种也返回了自增值。只是这个值是放在了 info.ID中。htm

SqlServer的特性批量添加操做
1         // 批量插入数据。(仅支持Sql Server)
2         var lst = new List<Users>();
3         lst.Add(new Users());
4         lst.Add(new Users());
5         lst.Add(new Users());
6         lst.Add(new Users());
7         Users.Data.SqlBulkCopy(lst);
框架约定

当属性未赋值时,也就是属性为null时。是不会产生对应的字段SQL的。

如:

1 new Users() { UserName = "张三" }.Insert();

Users实体实际上还有不少字段,好比PassWord、GenderType、LoginCount等等。

由于咱们没有对其赋值,则为null 因此。数据库是不会对其进行赋值的。也就是等价的SQL为:

1 insert into Members_User (UserName)Values("张三")

 

导航

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

上一篇:Farseer.net轻量级开源框架 入门篇: 分类逻辑层

下一篇:Farseer.net轻量级开源框架 入门篇: 修改数据详解

广告时间

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

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

Farseer 意为:先知、预言家 一般在某些场合时,提供计谋、策略。也但愿该框架能给你们提供最大化的便捷。

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

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

1 new User { ID = 1, Name = "张三" }.Insert()
相关文章
相关标签/搜索