Ibatis.Net各类的作用说明(三)

本文深入探讨了IBatis框架中SqlMapper类的加载、分析配置及映射文件的过程,以及如何在非Web请求线程下正确使用SqlMapper。重点介绍了通过SqlMapper.SessionStore参数解决在非Web环境下获取HttpContext容器的问题,并提供了详细步骤和解决策略。

一、SqlMapper类

  Ibatis中,加载、分析配置以及映射文件是在创建SqlMapper实例的时候进行的,另外对数据库的操作,也是在SqlMapper实例上调用方法来完成。在IBatis外部的程序中,创建SqlMapper的实例的方式是:

ISqlMapper mapper = Mapper.Instance();

  在第一次调用Mapper.Instance()的时候,由DomSqlMapBuilder对象解析SqlMap.config(默认路径和命名)文件来创建SqlMapper实例,然后会缓存该mapper对象,如果程序运行过程中,修改了映射文件,那么再调用Mapper.Instance()创建SqlMapper实例时,SqlMapper会被重新加载创建。相当于一个文件缓存依赖,这个文件缓存依赖由DomSqlMapBuilder.ConfigureAndWatch方法来实现。

如果你不希望修改了配置文件就重新加载,可以通过

ISqlMapper mapper = builder.Configure();

来创建实例。具体的位置写法,可以第二篇。

  IBatis.net的这个东西有个地方不好,默认是使用HttpContext作为xxx容器的。

  当非Web请求线程调用时,如Timer调用时会报如下错误:

ibatis.net:WebSessionStore: Could not obtain reference to HttpContext

  这个问题可以在创建SQLMapper的时候指定

SqlMapper.SessionStore = new HybridWebThreadSessionStore(sqlMapper.Id);

/// <summary>
/// 初始化
/// </summary>
/// <param name="sqlMapperPath"></param>
public void InitMapper(string sqlMapperPath)
{
  ConfigureHandler handler = new ConfigureHandler(Configure);
  DomSqlMapBuilder builder = new DomSqlMapBuilder();
  _mapper = builder.ConfigureAndWatch(sqlMapperPath, handler);
  _mapper.SessionStore = new IBatisNet.DataMapper.SessionStore.HybridWebThreadSessionStore(_mapper.Id);
}
  就可以解决问题。
  详细解释见:http://www.iloveher.cn/ibatis/hybridwebthreadsessionstore.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值