导航

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

上一篇: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,我们先看下DbProvider的工作方式,如下图:

每个数据库类型都会包含有自己的Provider。 这个Provider主要是提供数据库的特有的特性。

举个例子,在Sqlserver中。对于表名、字段名的保护符号是:[]  中括号。为了避免一些名称定义成SQLSERVER特有的关键词,可以理解为是一种转义符。而MySql用的是:  ‘’  两个单引号。

总结

怎么样?感觉是不是又回到了DbHelper的时代了。如果你担心ORM的性能慢,有这种强破症,你完全可以使用这种方式进行底层的访问。

按这种ORM性能的程度访问,可以分为三种:

完全使用ORM,返回List实体。

只使用ORM的操作,但返回DataTable数据。少了DataTable转到实体的性能消耗(非常昂贵的,貌似外文书都是这么翻译的)。

完全不使用。回到DbHelper方式。

以上三种方式都是支持的。

导航

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

上一篇: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语句的更多相关文章

  1. Farseer.net轻量级开源框架 中级篇:SQL执行报告

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 数据库切换 下一篇:Farseer.net轻量级开源框架 中级篇: 探究ORM(M ...

  2. Farseer.net轻量级开源框架 中级篇:探究ORM(Mapping)

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: SQL执行报告 下一篇:Farseer.net轻量级开源框架 中级篇: Cooki ...

  3. Farseer.net轻量级开源框架 中级篇:数据库切换

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 动态数据库访问 下一篇:Farseer.net轻量级开源框架 中级篇: SQL执行 ...

  4. Farseer.net轻量级开源框架 中级篇:Cookies、Session、Request

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 探究ORM(Mapping) 下一篇:Farseer.net轻量级开源框架 中级篇 ...

  5. Farseer.net轻量级开源框架 中级篇:常用的扩展方法

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: BasePage.BaseController.BaseHandler.BaseM ...

  6. Farseer.net轻量级开源框架 中级篇:事务的使用

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: Where条件的终极使用 下一篇:Farseer.net轻量级开源框架 中级篇: ...

  7. Farseer.net轻量级开源框架 中级篇:DbFactory数据工厂

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 执行SQL语句 下一篇:Farseer.net轻量级开源框架 中级篇: 数据绑定 ...

  8. Farseer.net轻量级开源框架 中级篇:动态数据库访问

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 自定义配置文件 下一篇:Farseer.net轻量级开源框架 中级篇: 数据库切换 ...

  9. Farseer.net轻量级开源框架 中级篇:UrlRewriter 地址重写

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: Cookies.Session.Request 下一篇:Farseer.net轻量 ...

随机推荐

  1. win7 多用户远程登录

    win7多用户远程登录 远程桌面服务使局域网(LAN)上的计算机可以连接到服务器(也称为远程计算机)并运行位于服务器上的程序.这可以只需要在1台机器上安装应用程序,其他机器共享使用.远程桌面连接使用远 ...

  2. 006 Cisco switch prewired

    Switch>en Switch#config t Enter configuration commands, one per line.  End with CNTL/Z. Switch(co ...

  3. HTML5: 本地缓存

    实现前端缓存,除了自己创建js保存(參考:http://blog.csdn.net/clementad/article/details/46807641).还能够利用html5的storage方法. ...

  4. 面试题之strcpy/strlen/strcat/strcmp的实现

    阿里的电面要我用C/C++实现一个字符串拷贝的函数,虽然以前写过 strcpy 的函数实现,但时间过去很久了,再加上有点紧张,突然就措手不及了.最后写是写出来了,但没考虑异常的情况,面试官好像很不满意 ...

  5. 2015 Multi-University Training Contest 9-1007 Travelling Salesman Problem

    Problem Description Teacher Mai is in a maze with n rows and m columns. There is a non-negative numb ...

  6. NYOJ 496 [巡回赛-拓扑排序]

    链接:click here 题意: 巡回赛 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描写叙述 世界拳击协会(WBA)是历史最悠久的世界性拳击组织,孕育了众多的世界冠军, ...

  7. DSPC6748中某问题的解决方式

    因为之前没有做过DSP相关的开发,属于菜鸟中的菜鸟.出现故障后.不知道从哪方面来解决这些小问题. 开发环境:CCS5.5.0 开发板:TI公司的TMS320C6748 问题: 控制台出现初始化结束后多 ...

  8. LeetCode——Regular Expression Matching

    Implement regular expression matching with support for '.' and '*'. '.' Matches any single character ...

  9. ios22--动画

    控制器: // // ViewController.m // 07-渐变动画 // // Created by xiaomage on 15/12/30. // Copyright © 2015年 小 ...

  10. 关于Android热点模式下的UDP广播

    最近尝试让easylink3在热点模式下连接,发现用普通的广播地址会报错,Network unreachable 尝试按照stackoverflow上的方法: public static int ge ...