Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射
上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作
下一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程数据操作
在V1.0中,新增了存储过程的映射。在以往的版本中,操作存储过程的代码没有这么优雅,必须在每次操作的时候传入存储过程名称、in参数、out参数。
在这个版本之后,存储过程也享受了映射带来的好处:
- 支持定义实体
- 实体中定义in参数、out参数
- 更易于维护(维护仅是针对实体结构)
这是这个版本的一个小创新点。以往我们调用存储过程时,只能在逻辑段里手动写参数名称、存储过程名称。
这给我们带来了维护灾难,同时最重要的是不支持硬编码方式也是很不优雅的。在新版中实现了这一支持。
- public class Proc : DbContext<Proc>
- {
- [Set(Name = "sp_Info_User")]
- public ProcSet<InfoUserVO> InfoUser { get; set; }
- [Set(Name = "sp_Insert_User")]
- public ProcSet<InsertUserVO> InsertUser { get; set; }
- [Set(Name = "sp_List_User")]
- public ProcSet<ListUserVO> ListUser { get; set; }
- [Set(Name = "sp_Value_User")]
- public ProcSet<ValueUserVO> ValueUser { get; set; }
- }
它的各个存储过程由ProcSet封装。针对数据库表提供的一系列执行的操作。被ProcSet包含的就是存储过程字段了。这里有点特殊的是,除了是查询的结果集的映射外,包含了参数传入的映射,并且区分in/out。
存储过程实体类:
- public class InsertUserVO
- {
- /// <summary> 用户ID </summary>
- [Field(IsOutParam = true)]
- public int? ID { get; set; }
- /// <summary> 用户名 </summary>
- [Field(IsInParam = true)]
- public string UserName { get; set; }
- /// <summary> 密码 </summary>
- [Field(IsInParam = true)]
- public string PassWord { get; set; }
- }
存储过程与表、视图的区别比较大。在上面代码中,看到使用了IsOutParam和IsInParam的特性。标记后,在执行存储过程时,会根据这些标记生成SQL参数化。传入到存储过程中。
与此同时,如果该条存储过程执行后,会返回数据列表时,也会对应的返回当前这个实体列表。就根据我们对表进行查询时一样。
通过存储过程的映射,我们不需要每次调用时手动指定他们了。让我们存储过程也能ORM了。
只有一个:FieldAttribute,它与表的特性是共同的。只不过它多了一些针对存储过程而设计的:
我们先来看下面的表格:
序号 | 变量 | 注释 | 类型 | 适用范围 | 说明 |
1 | Name | 数据库字段名称 | string | 全部 |
指定表字段、视图字段名称、存储过程参数的名称、数据库函数 未显示指定时,默认使用当前的类属性名称作为缺省名称 |
2 | IsOutParam | 指示字段是否为存储过程中输出的参数 | bool | 存储过程 |
默认:false 设为:true 将作为SQL参数值传入,并配合Name声明参数名称,与InParam区别是Out在数据库存储过程中也要声明为该变量是out 即在存储过程中改变时,会将值返回来 |
3 | IsInParam | 指示字段是否为存储过程中输入的参数 | bool | 存储过程 |
默认:false 设为:true 将作为SQL参数值传入,并配合Name声明参数名称 |
只是多了第2、3条属性说明(与TableSet、ViewSet的特性:FieldAttribute,是同一个)。
通过设置它们,很容易让Farseer.Net哪些是参数及输入输出。
存储过程的映射非常简单,当然它的操作也是非常简单,在下一篇我们可以学习到它提供的4种方法用来操作。
这篇就结束在这,总结,其实没什么好总结的了。
上一篇: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 入门篇:存储过程实体类映射的更多相关文章
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射 下一篇:Farseer.net轻量级ORM开源 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射 下一篇:Farseer.net轻量级ORM ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作 下一篇:Farseer.net轻量级ORM开源框 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库上下文
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置文件 下一篇:Farseer.net轻量级ORM开源 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射 下一篇:Farseer.net轻量级ORM开源框 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库上下文 下一篇:Farseer.net轻量级ORM开源框 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置文件
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:新版本说明 下一篇:Farseer.net轻量级ORM开源框架 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:新版本说明
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:没有了 下一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:数据库配置 前言 V1.x版本终于到来了.本次 ...
- Farseer.net轻量级ORM开源框架 V1.x 教程目录
本篇教程将以Ver 1.x版本进行详细使用讲解 大家有任何疑问可以加入我们的官方QQ群进行讨论.QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net 整个 ...
随机推荐
- C项目实践--学生成绩管理系统
1.功能需求分析 学生成绩管理系统是对学生基本信息及成绩的管理.本程序主要实现了对学生的学号.姓名等基本信息以及各项学科成绩进行增加.删除.修改.查询和保存到磁盘文件等操作.主要功能描述如下: (1) ...
- ES6 模块化(Module)export和import详解 export default
ES6 模块化(Module)export和import详解 - CSDN博客 https://blog.csdn.net/pcaxb/article/details/53670097 微信小程序笔记 ...
- 编译Android VNC Server【转】
本文转载自:http://www.cnblogs.com/fengfeng/p/3289292.html 1,在如下地址checkout源代码,我checkout的版本为0.9.7http://cod ...
- POJ3159 Candies —— 差分约束 spfa
题目链接:http://poj.org/problem?id=3159 Candies Time Limit: 1500MS Memory Limit: 131072K Total Submiss ...
- 【基于libRTMP的流媒体直播之 AAC、H264 解析】
前文我们说到如何在基于 libRTMP 库的流媒体直播过程中推送 AAC .H264 音视频流.本文以上文为基础,阐释如何对 RTMP 包进行解析.重组得到原始的 AAC 音频帧以及 H264 码流. ...
- Luogu P1113 杂务 【拓扑排序】 By cellur925
题目传送门 这题我们一看就知道是拓扑排序,然而在如何转化问题上花了大工夫,一个小时后最后还是无奈看了题解qwq. 显然我们可以对于每个任务,从他的前导任务到他连一条边,最后我们可以得到一个DAG.在这 ...
- js实现打字效果
<!DOCTYPE html> <html> <head> <meta charset='utf-8'> <title>js typing& ...
- 再谈spark部署搭建和企业级项目接轨的入门经验(博主推荐)
进入我这篇博客的博友们,相信你们具备有一定的spark学习基础和实践了. 先给大家来梳理下.spark的运行模式和常用的standalone.yarn部署.这里不多赘述,自行点击去扩展. 1.Spar ...
- java String, StringBuffer ,StringBulider 区别
1. String 是不可变的(immutable): 创建后不能修改: 2. StringBuffer 线程安全的,可变字符串: 3. StringBuilder 线程不安全,所以性能比较高
- Microsoft函数调用约定
Microsoft函数调用约定 对于所有调用共有的约定:ebx.ebp.esi.edi都是calle-save,即由被调用的函数负责它们的保存(如果被调用函数用到了这些寄存器的话) 先看函数调用发生了 ...