iBatis.Net(4):DataMapper API

在iBatis.Net中,可以通过SqlMapper实例访问DataMapper API,其实以前写的都是一些iBatis.Net的概念和一些配置的问题,从这一篇开始,才是真正的精髓,也是我们使用iBatis.NET真正开始完整我们对数据库的任务的开始,这一篇我主要写一些DataMapper API,的定义、作用、使用方式,很遗憾,这一篇应该还是不会出现任何实例,因为还没有数据实体类和映射文档,这将会在下一篇写到

Insert/Delete/Update

 

public object Insert(string statementName, object parameterObject);
 
public int Delete(string statementName, object parameterObject);
 
public int Update(string statementName, object parameterObject);

从方法名就可以看的出来他们要执行的操作,如果您没有使用过iBatis,肯定会疑惑为什么没有一个叫做Select的方法,的确,再我第一次接触他的时候,也这么想,不过如果您能完整的看完这一篇的话,就回觉得这个疑惑其实有点蠢啦 ,呵呵,谁没有蠢过呢

参数statementName:在映射文件中定义的节点id属性值(下篇详细写到)

参数parameterObject:输入参数,通常是一个实体类

返回值:在Delete和Update方法中,方法返回受影响的行数,如果在映射文件节点Insert中加入了selectKey,就可以产生主键并返回它

 

QueryForObject

 

public object QueryForObject(string statementName, object parameterObject);
public T QueryForObject<T>(string statementName, object parameterObject);
public T QueryForObject<T>(string statementName, object parameterObject, T instanceObject);
public object QueryForObject(string statementName, object parameterObject, object resultObject)

注意啦,Select来啦,这些方法的实质就是Select,如果我们查询的结果是一行数据,并且在映射文件中定义了与查询结果对应的实体类,那么执行此方法返回的就是一个这个实体类的对象,在实际引用中经常会用到组合的查询操作,那么就可以在程序运行中管理返回对象的类型,我们可以把对象作为第三个参数传递到方法中

 

QueryForList

public IList<T> QueryForList<T>(string statementName, object parameterObject);

public IList QueryForList(string statementName, object parameterObject);

public void QueryForList<T>(string statementName, object parameterObject, IList<T> resultObject);

public void QueryForList(string statementName, object parameterObject, IList resultObject);

public IList<T> QueryForList<T>(string statementName, object parameterObject, int skipResults,int maxResults);

public IList QueryForList(string statementName, object parameterObject, int skipResults, int maxResults);

QueryForObject方法是用来返回一行数据,那么这里的QueryForList就是返回多行结果啦,他返回的是一个实现了IList结构的列表对象,当然也可以是泛型类型的,这样就会省点装箱拆箱的过程啦,参数skipResults,表示从结果行掉过skipResults行后返回,maxResults表示返回的行数(当然,如果结果中根本没超过maxResults行,那么这个参数就失效啦)

 

 

QueryWithRowDelegate

 

public IList<T> QueryWithRowDelegate<T>(string statementName, object parameterObject, RowDelegate<T> rowDelegate);
public IList QueryWithRowDelegate(string statementName, object parameterObject, RowDelegate rowDelegate);
如果我们在我们返回结果集的时候,需要对结果集中的对象进行一些处理,比如类型转换,或者需要过滤到我们定义的某种规则的行,我们就可以使用这个方法,向方法中传递一个RowDelegate委托方法来处理这些事情
 
 
 

QueryForDictionary/QueryForMap

 

public IDictionary<K, V> QueryForDictionary<K, V>(string statementName, object parameterObject, string keyProperty);

public IDictionary QueryForDictionary(string statementName, object parameterObject, string keyProperty);

public IDictionary<K, V> QueryForDictionary<K, V>(string statementName, object parameterObject, string keyProperty, string valueProperty);

public IDictionary QueryForDictionary(string statementName, object parameterObject, string keyProperty, string valueProperty);

public IDictionary<K, V> QueryForDictionary<K, V>(string statementName, object parameterObject, string keyProperty, string valueProperty, DictionaryRowDelegate<K, V> rowDelegate);

public IDictionary QueryForMap(string statementName, object parameterObject, string keyProperty);

public IDictionary QueryForMap(string statementName, object parameterObject, string keyProperty, string valueProperty);

public IDictionary QueryForMapWithRowDelegate(string statementName, object parameterObject, string keyProperty, string valueProperty, DictionaryRowDelegate rowDelegate);

 

如果您理解了QueryForList,就不难理解QueryForDictionary,他返回一个实现了IDictionary接口的字典类型,他的key值是由keyProperty指定的,如果我们不需要结果集中存放的是整个对象,而是某一列值,还可以使用valueProperty指定一个值来确定返回结果中的列值

 

Session

在iBatis.Net中,一个会话就是一个Connection和一个Transaction容器,使用一个using语句块打开一个Connection

using(IDalSession mySession=sqlMap.OpenConnection())
{
    //do something
}

Connection

 

public ISqlMapSession OpenConnection();

public ISqlMapSession OpenConnection(string connectionString);

public void CloseConnection();

可以使用一个Open和一个Close定界一个Connection,或者使用一个using语句块,在这个语句块执行完毕后就会自动调用一个CloseConnection方法

 

Transaction

 

 

public ISqlMapSession BeginTransaction();

public ISqlMapSession BeginTransaction(bool openConnection);

public ISqlMapSession BeginTransaction(IsolationLevel isolationLevel);

public ISqlMapSession BeginTransaction(string connectionString);

public ISqlMapSession BeginTransaction(bool openNewConnection, IsolationLevel isolationLevel);

public ISqlMapSession BeginTransaction(string connectionString, IsolationLevel isolationLevel);

public ISqlMapSession BeginTransaction(string connectionString, bool openNewConnection, IsolationLevel isolationLevel);

public void CommitTransaction();

public void CommitTransaction(bool closeConnection);

public void RollBackTransaction();

public void RollBackTransaction(bool closeConnection);

对数据库的操作,当然少不了对事务的支持啦,当然iBatis.Net也提供给了我们很好的对事务的支持,当然,我们还是可以使用TransactionScope的方式使用事务,这些方法的使用,我觉得就没必要解释了吧,开始,执行,若不成功、抛出异常,则回滚事务,然后进行相应的操作,这就看你要怎么设计啦

转载于:https://www.cnblogs.com/h20064528/archive/2012/09/25/2703190.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
IBatisNet.DataMapper 1.6.1.0之简单三层 首先介绍Solution的架构,一共分四个项目: Web :前台应用; BLL :业务处理层,如果嫌麻烦,可以再进一步抽象出来,然后将代码放置Web层的aspx.cs里面; Model :这个就不多说了,地球人都知道(数据实体类) SqlMaps:资源类,把配置文件和sql mapper文件全部打包起来。 二个文件夹: Include :iBatis.Net架构的dll文件 Log :放置log文件的文件夹,在web.config里配置 1.在一些特定的环境下,一站式的解决方案未必有效 系统的部分或全部数据来自现有数据库,处于安全考虑,只对开发团队提供几条Select SQL(或存储过程)以获取所需数据,具体的表结构不予公开。 开发规范中要求,所有牵涉到业务逻辑部分的数据库操作,必须在数据库层由存储过程实现。(银行大多有这样的限制) 系统数据处理量巨大,性能要求极为苛刻,这往往意味着我们必须通过经过高度优化的SQL语句(或存储过程)才能达到系统性能设计指标。 2.iBATIS之于小型、简单系统:非常适用 iBATIS自己就很小并且简单 iBATIS不会对现存应用的设计或者数据库结构强加任何影响 iBATIS非常适合于有成长趋势的系统 3.iBATIS之于大型、企业级系统:为之而设计 iBATIS的某些特性使得它能够高效地处理大型数据集 iBATIS允许你用多种方式建立从对象到数据库的映射关系 MySpace已应用 4.使用于任何类型的关系数据库: 应用数据库 企业数据库 私有数据库 遗留数据库 简单性 性能 明确分工 可移植性:Java、.Net或者其他 开源 5.何时不该使用iBATIS 当你能永远拥有完全控制权 当你的应用需要完全动态的SQL 当你并没有使用关系数据库时 当iBATIS不起作用时
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值