Farseer.net轻量级开源框架 中级篇:执行SQL语句
上一篇:Farseer.net轻量级开源框架 中级篇: 事务的使用
下一篇:Farseer.net轻量级开源框架 中级篇: DbFactory数据工厂
使用自定义SQL,或者存储过程。仍然使用:DbExecutor ,没错,其实框架最终执行,都是到这个类里把生成的SQL传进来的。
因此你也可以使用自己传进来的SQL进行执行你想要的结果。
我们先看下这里面有哪些方法吧。(其实很像你们以前接触过的:DbHelper....)
/// <summary>
/// 返回第一行第一列数据
/// </summary>
/// <param name="cmdType">执行方式</param>
/// <param name="cmdText">SQL或者存储过程名称</param>
/// <param name="parameters">参数</param>
public object ExecuteScalar(CommandType cmdType, string cmdText, params DbParameter[] parameters) /// <summary>
/// 返回受影响的行数
/// </summary>
/// <param name="cmdType">执行方式</param>
/// <param name="cmdText">SQL或者存储过程名称</param>
/// <param name="parameters">参数</param>
public int ExecuteNonQuery(CommandType cmdType, string cmdText, params DbParameter[] parameters) /// <summary>
/// 返回数据(IDataReader)
/// </summary>
/// <param name="cmdType">执行方式</param>
/// <param name="cmdText">SQL或者存储过程名称</param>
/// <param name="parameters">参数</param>
public IDataReader GetReader(CommandType cmdType, string cmdText, params DbParameter[] parameters) /// <summary>
/// 返回数据(DataSet)
/// </summary>
/// <param name="cmdType">执行方式</param>
/// <param name="cmdText">SQL或者存储过程名称</param>
/// <param name="parameters">参数</param>
public DataSet GetDataSet(CommandType cmdType, string cmdText, params DbParameter[] parameters) /// <summary>
/// 返回数据(DataTable)
/// </summary>
/// <param name="cmdType">执行方式</param>
/// <param name="cmdText">SQL或者存储过程名称</param>
/// <param name="parameters">参数</param>
public DataTable GetDataTable(CommandType cmdType, string cmdText, params DbParameter[] parameters)
CommandType cmdType:枚举,意为要使用哪种命令传输。
namespace System.Data
{
// 摘要:
// 指定如何解释命令字符串。
public enum CommandType
{
// 摘要:
// SQL 文本命令。(默认。)
Text = ,
//
// 摘要:
// 存储过程的名称。
StoredProcedure = ,
//
// 摘要:
// 表的名称。
TableDirect = ,
}
}
string cmdText:SQL语句,或者存储过程的名称。
params DbParameter[] parameters:参数列表 比如:
//最原始的方式。
using (DbExecutor db = new DbExecutor(DataBaseType.SqlServer, "User ID=sa;Password=123456;Pooling=true;Data Source=.;Initial Catalog=Farseer;", , System.Data.IsolationLevel.ReadCommitted))
{
// 执行插入的操作。
db.ExecuteNonQuery(System.Data.CommandType.Text, "insert into users(UserName,RoleID) Values('张三',0)");
// 操作完成后,记得要关闭,释放资源。 如果你像我这样使用了using 下面是可以不用执行的。如果没用,则必须加上。
db.Close(true);
}
上面DEMO,是做了一个插入的操作。ExecuteNonQuery 返回 “影响的行数” int 类型。 意思是数据库表中记录的影响行数。
// 利用DbFactory,创建了DbExecutor对象
// 第1个参数 0 代表的是数据库配置:DbConfig 的索引项。在:~/App_Data/Db.config 中
using (DbExecutor db = DbFactory.CreateDbExecutor(, System.Data.IsolationLevel.ReadCommitted))
{
// 执行插入的操作。
DataTable dt = db.GetDataTable(System.Data.CommandType.Text, "select * from users");
// 可以依赖扩展方法把DataTable 转成 List<User> 哦
List<Users> lst = dt.ToList<Users>();
// 操作完成后,记得要关闭,释放资源。 如果你像我这样使用了using 下面是可以不用执行的。如果没用,则必须加上。
db.Close(true);
}
上面DEMO中。使用GetDataTable方式,获取DataTable。框架对DataTable 提供了 转到 List 实体类的扩展方法哦。
// 利用Users泛型,创建了DbExecutor对象
// 会通过对Users缓存的反射结果,查询这个实体的数据库连接方式。(其实还是转到数据库配置索引项)
using (DbExecutor db = DbFactory.CreateDbExecutor<Users>(System.Data.IsolationLevel.ReadCommitted))
{
// 这里,我们用了一个新的类:SqlServerProvider 或者 DbProvider
// SqlServerProvider 继承在 DbProvider
var provider = new SqlServerProvider(); // 或者也可以用 DbFactory.CreateDbProvider 通过传入的Users 来判断你的数据库类型(有可能你的不是SqlServer)
// DbProvider 是用来为我们提供不同数据库的一些特性。比如下文中的创建数据库的参数,或者数据库的保护符号,或者参数符号的前缀。不同数据库的这些都是不一样的。
var provider = DbFactory.CreateDbProvider<Users>(); db.ExecuteNonQuery(System.Data.CommandType.Text, "update users set username = @userName where id = @id", provider.CreateDbParam("userName", "张三", DbType.String, ));
}
这种方式,采用了 参数的方式进行提交。可以避免 ASP当时最危险的漏洞:SQL注入
什么是DbProvider,我们先看下DbProvider的工作方式,如下图:

每个数据库类型都会包含有自己的Provider。 这个Provider主要是提供数据库的特有的特性。
举个例子,在Sqlserver中。对于表名、字段名的保护符号是:[] 中括号。为了避免一些名称定义成SQLSERVER特有的关键词,可以理解为是一种转义符。而MySql用的是: ‘’ 两个单引号。
怎么样?感觉是不是又回到了DbHelper的时代了。如果你担心ORM的性能慢,有这种强破症,你完全可以使用这种方式进行底层的访问。
按这种ORM性能的程度访问,可以分为三种:
完全使用ORM,返回List实体。
只使用ORM的操作,但返回DataTable数据。少了DataTable转到实体的性能消耗(非常昂贵的,貌似外文书都是这么翻译的)。
完全不使用。回到DbHelper方式。
以上三种方式都是支持的。
上一篇:Farseer.net轻量级开源框架中级篇: 事务的使用
下一篇:Farseer.net轻量级开源框架 中级篇: DbFactory数据工厂
QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net
Farseer.Net是一款ORM框架 + 常用工具 + 扩展集合。
Farseer 意为:先知、预言家 通常在某些场合时,提供计谋、策略。也希望该框架能给大家提供最大化的便捷。
ORM:其英文全称是:Object(对象) Relational(关系) Mapping(映射)
Farseer.Net的目标是:快速上手、快速开发、简单方便。
new User { ID = , Name = "张三" }.Insert()
Farseer.net轻量级开源框架 中级篇:执行SQL语句的更多相关文章
- Farseer.net轻量级开源框架 中级篇:SQL执行报告
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 数据库切换 下一篇:Farseer.net轻量级开源框架 中级篇: 探究ORM(M ...
- Farseer.net轻量级开源框架 中级篇:探究ORM(Mapping)
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: SQL执行报告 下一篇:Farseer.net轻量级开源框架 中级篇: Cooki ...
- Farseer.net轻量级开源框架 中级篇:数据库切换
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 动态数据库访问 下一篇:Farseer.net轻量级开源框架 中级篇: SQL执行 ...
- Farseer.net轻量级开源框架 中级篇:Cookies、Session、Request
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 探究ORM(Mapping) 下一篇:Farseer.net轻量级开源框架 中级篇 ...
- Farseer.net轻量级开源框架 中级篇:常用的扩展方法
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: BasePage.BaseController.BaseHandler.BaseM ...
- Farseer.net轻量级开源框架 中级篇:事务的使用
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: Where条件的终极使用 下一篇:Farseer.net轻量级开源框架 中级篇: ...
- Farseer.net轻量级开源框架 中级篇:DbFactory数据工厂
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 执行SQL语句 下一篇:Farseer.net轻量级开源框架 中级篇: 数据绑定 ...
- Farseer.net轻量级开源框架 中级篇:动态数据库访问
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 自定义配置文件 下一篇:Farseer.net轻量级开源框架 中级篇: 数据库切换 ...
- Farseer.net轻量级开源框架 中级篇:UrlRewriter 地址重写
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: Cookies.Session.Request 下一篇:Farseer.net轻量 ...
随机推荐
- Python学习系列之面向对象
概述 一.Python编程方式 面向过程编程:根据业务逻辑从上到下磊代码 面向函数编程:将某功能代码封装到函数中,将来直接调用即可,无需重新写 面向对象编程:对函数进行分类.封装 二.面向过程编程 w ...
- 【SSH进阶之路】Hibernate搭建开发环境+简单实例(二)
Hibernate是很典型的持久层框架,持久化的思想是很值得我们学习和研究的.这篇博文,我们主要以实例的形式学习Hibernate,不深究Hibernate的思想和原理,否则,一味追求,苦学思想和原理 ...
- Office 针式打印机如何插入色带
1 打开盖子,用手按住我按的地方 2 向下翻起 3 翻转完成 4 装入色带(有旋钮的那面朝向自己,装入之后,按箭头方向旋转以拉紧色带,下图圈出来的2是色带导向架) 5 把色带绷直,如下 ...
- JAVA编程思想(2) - 操作符(二)
5. 直接常量 -一般来说,假设程序里使用了"直接常量",编译器能够准确的知道要生成什么样的类型.但有时候却是模棱两可的. 这时候须要我们对编译器进行适当的"指导&quo ...
- NPOI2.2.0.0实例详解(十)—设置EXCEL单元格【文本格式】 NPOI 单元格 格式设为文本 HSSFDataFormat
NPOI2.2.0.0实例详解(十)—设置EXCEL单元格[文本格式] 2015年12月10日 09:55:17 阅读数:3150 using System; using System.Collect ...
- 阿里云CentOS7.3搭建多用户私有git服务器(从安装git开始)
起因 自己会有练手的不敢公开的项目,就自己搭建个服务器放自己的渣代码了. 在经历了连不上服务器.没有访问权限.没法提交以后,我打通了任督二脉. 我这个git服务器适合条件:1.就那么几个人小项目,不是 ...
- Mac OS 10.10.3下Apache + mod_wsgi配置【一】
[一] 首先,MAC是自带Apache的,在/private/etc/apache2路径下,能够使用apachectl -v查看版本号.我的版本号例如以下: Server version: Apach ...
- jquery跨域请求json数据
//服务端生成json数据json.php <?php $json=array("Volvo","BMW","SAAB"); $cb ...
- python generator iterator和iterable object
1 iterable object list.dict.set.tuple.file(在每行上iterate)等都是iterable object,但是它们不是iterator.但是它们可以转换成it ...
- kentico7中设置site的default page
在SiteManager中,Settings中,选择好站点,然后Content,Default alias path