最近加班比较忙,时间也比较琐碎,蛮久没有写东西了。这次就总结一下自己使用IBatis.net的一些总结吧。

IBatis简介

IBatis.net是一款开源的Orm框架,应该算是从java的IBatis项目演化而来的基于C#的Orm框架。

官方网站:http://www.mybatis.org/

项目下载地址:http://code.google.com/p/mybatisnet/

IBatis使用

1)、配置文件:providers.config---数据库提供者的配置文件,主要用于配置使用的数据库类型;SqlMap.config:配置入口文件,用于配置指向的数据提供者文件和各类sql映射文件。配置文件名称可自行设定(SqlMap.Config为默认的配置文件名).

2)、配置文件的初始化:

public class MyMapper
{
public static string DbMapperFile = @"ConfigFile\SqlMap.config"; ///配置文件名
private static object mLock = new object(); private static volatile ISqlMapper _mapper = null;
/// <summary>
///
/// </summary>
/// <param name="obj"></param>
public static void Configure(object obj)
{
_mapper = null;
} public static ISqlMapper SqlMapper
{
get
{
if (_mapper == null)
{
lock (mLock)
{
if (_mapper == null)
{
ConfigureHandler handler = new ConfigureHandler(Configure);
DomSqlMapBuilder builder = new DomSqlMapBuilder();
_mapper = builder.ConfigureAndWatch(DbMapperFile, handler); //监视配置文件,不监视:builder.Configure();
}
}
}
return _mapper;
}
}
}

 初始化一个Dal'操作基类:

/// <summary>
/// Dal抽象基类
/// </summary>
/// <typeparam name="T"></typeparam>
public abstract class BaseDal<T> where T : class
{
protected ISqlMapper sqlMapper = null;
public BaseDal()
{
sqlMapper = HisMapper.SqlMapper; }
public BaseDal(string configFile)
{
MyMapper.DbMapperFile = configFile;
sqlMapper = MyMapper.SqlMapper;
}
/// <summary>
/// 新增,底层默认返回Object
/// </summary>
/// <param name="statement"></param>
/// <param name="parameters"></param>
/// <returns></returns>
public object Add(string statement, object parameters)
{
return sqlMapper.Insert(statement, parameters);
}
/// <summary>
/// 删除
/// </summary>
/// <param name="statement"></param>
/// <param name="parameters"></param>
/// <returns></returns>
public int Delete(string statement, object parameters)
{
return sqlMapper.Delete(statement, parameters);
}
/// <summary>
/// 更新
/// </summary>
/// <param name="statement"></param>
/// <param name="parameters"></param>
/// <returns></returns>
public int Update(string statement, object parameters)
{
return sqlMapper.Update(statement, parameters);
}
/// <summary>
/// 查询返回集合
/// </summary>
/// <param name="statement"></param>
/// <param name="parameters"></param>
/// <returns></returns>
public IList<T> QueryForList(string statement, object parameters)
{
return sqlMapper.QueryForList<T>(statement, parameters);
}
/// <summary>
/// 查询返回对象
/// </summary>
/// <param name="statement"></param>
/// <param name="parameters"></param>
/// <returns></returns>
public object QueryForObj(string statement, object parameters)
{
return sqlMapper.QueryForObject(statement, parameters);
}
}

  3)、实体Orm操作实现:

一、创建实体类,包含实体对应字段的定义(略)

二、创建对应的Xml映射文件,例子如下

<?xml version="1.0" encoding="utf-8" ?>
<sqlMap namespace="MyBatis3Sample.Model" xmlns="http://ibatis.apache.org/mapping" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<alias>
<typeAlias alias="Customer" type="MySample.Model.Customer, MySample.Model" />
</alias> <!--Mapping Class To Sql Realation Teable-->
<resultMaps>
<resultMap id="CustomerResult" class="Customer">
<result property="CustomerId" column="CustomerId"/>
<result property="FirstName" column="FirstName"/>
<result property="LastName" column="LastName"/>
</resultMap>
</resultMaps> <!--Mapping The SQl StateMent about CRUD chenkai-->
<statements>
<insert id="New_Customer" parameterClass="Customer">
<![CDATA[INSERT INTO tbCustomer
( FirstName ,
LastName
)
VALUES ( #FirstName# , #LastName# )]]>
</insert>
<update id="Update_CustomerById">
<![CDATA[
update tbCustomer set FirstName=#FirstName#,SecondName=#SecondName#
where CustomerId=#CustomerId#
]]>
</update>
<select id ="Select_All_Customer" resultMap="CustomerResult">
<![CDATA[
select CustomerId,FirstName,LastName from tbCustomer
]]>
</select>
<select id="Select_CustomerById" extends="Select_All_Customer" resultMap="CustomerResult">
<![CDATA[
where CustomerId=#CustomerId#
]]>
</select>
<select id="Select_CustomerByNamePrefix" extends="Select_All_Customer" resultMap="CustomerResult">
<dynamic prepend=" where ">
<isNotEmpty prepend =" and ">
FirstName like '$FirstNamePrefix$%'
</isNotEmpty>
<isNotEmpty prepend =" and ">
LastName like '$LastNamePrefix$%'
</isNotEmpty>
</dynamic>
</select> <select id="Select_CustomerTotalCount" resultClass="int">
<![CDATA[
select count(CustomerId) from tbCustomer
]]>
</select>
</statements>
</sqlMap>

  分解:

a、<resultMaps>可包含多个resultmap---字段配置映射关系,将查出的字段映射到对应的类的对应字段

b、<statements>可包含多个statement---配置Sql语句,大致为select、insert 、update、delete,其他的没有太过深究。

c、“#FirstName#”其中FirstName为传递的参数,IBatis会自动解析其类型,“'$FirstNamePrefix$%'” 为模糊查询时参数的编写方式,也可以通过参数拼接的方式实现。参数在传递时大小写敏感,这点要注意

d、注意<dymanic>的动态sql实现,主要是写法。

e、每个statement的Id必须为一,不可存在重复,即使是在同一项目的其他的xml配置中也不可存在和当前statement的Id一致的statement,否则会报错。因为在ibatis进行配置读取时,会将各个statement加载,要求statement的id必须为一

f、statement中配置resultMap和resultClass的区别,如果不配置resultMap和resultClass会默认返回object类型,resultMap一般是用于配置到对应的映射配置;resultClass一般用于指向指定的类型,例如string/object等。

g、 <![CDATA[]]>类似于@“”,将语句标识为不转义。

总结

用Ibatis有一段时间了,基于sql编写的实现感觉上还是不错的。

附上部分帮助文件,例子代码就不上传了,因为是在实现的部分很简单也没有明确的测过。

Mapper提示文件

IBatis.net初步使用的更多相关文章

  1. 【转】ibatis的简介与初步搭建应用

    [转]ibatis的简介与初步搭建应用 一.ibatis的简介 ibatis是什么东西就不介绍了,自己去找谷老师. 这里讲下自己的使用体会.之前自己学过Hibernate,是看尚学堂的视频教学的,看完 ...

  2. [入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二)

    [入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二) Date  周六 10 一月 2015 By 钟谢伟 Category website develop ...

  3. iBatis.net技术实践

    随着大数据技术的兴起和快速发展,人们更多的开始关注HDFS.HBase.Hive等技术.但是谈到强一致性,我们又不得不回归现实,只能继续沿用RDBMS存储强一致性的数据.我们日常接触到的绝大多数的应用 ...

  4. ibatis源码学习4_参数和结果的映射原理

    问题在详细介绍ibatis参数和结果映射原理之前,让我们先来思考几个问题.1. 为什么需要参数和结果的映射?相对于全自动的orm,ibatis一个重要目标是,通过维护POJO与SQL之间的映射关系,让 ...

  5. 移动端之Android开发的几种方式的初步体验

    目前越来越多的移动端混合开发方式,下面列举的大多数我都略微的尝试过,就初步的认识写个简单的心得: 开发方式 开发环境 是否需要AndroidSDK 支持跨平台 开发语言&技能 MUI Win+ ...

  6. 值得注意的ibatis动态sql语法格式

    一.Ibatis常用动态sql语法,简单粗暴用一例子 <select id="iBatisSelectList" parameterClass="java.util ...

  7. org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):

    org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): da.huying.usermanag ...

  8. CSharpGL(29)初步封装Texture和Framebuffer

    +BIT祝威+悄悄在此留下版了个权的信息说: CSharpGL(29)初步封装Texture和Framebuffer +BIT祝威+悄悄在此留下版了个权的信息说: Texture和Framebuffe ...

  9. Android自定义View初步

    经过上一篇的介绍,大家对于自定义View一定有了一定的认识,接下来我们就以实现一个图片下显示文字的自定义View来练习一下.废话不多说,下面进入我们的正题,首先看一下我们的思路,1.我们需要通过在va ...

随机推荐

  1. hadoop ,传智播客目录

    一.Hadoop入门,了解什么是Hadoop 1.Hadoop产生背景 2.Hadoop在大数据.云计算中的位置和关系 3.国内外Hadoop应用案例介绍 4.国内Hadoop的就业情况分析及课程大纲 ...

  2. Tomcat6 Session建立机制简要

    底:  测试部门做压力测试, 结果没多久新闻,出现OutOfMemory. 查找原因,通过监视工具,查找StandardSession(org.apache.catalina.session.Stan ...

  3. 浅谈TCP优化(转)

    很多人常常对TCP优化有一种雾里看花的感觉,实际上只要理解了TCP的运行方式就能掀开它的神秘面纱.Ilya Grigorik 在「High Performance Browser Networking ...

  4. hdu 5035 概率论

    n服务形式,各服务窗口等候时间指数公布,求所需的等待时间. 解: 相两点:首先,等到轮到他,然后就是送达时间. 潜伏期期望每个表单1/ki(1/ki,宣布预期指数公式).总的等待时间预期1/(求和ki ...

  5. REST Service 基础 A further step.

    1. REST Service虽然实现简单, 但也功能丰富, 可以用来实现各种基于Web的服务(service). 2. REST Service的一些特点: 1)平台无关 2) 语言无关 3)基于H ...

  6. macbook连接linuxserver后不显示matlab桌面[问题]

    macbook 登录远程linuxserver.Macbook今天,系统版本号10.9.4.这是更新,打开matlab当提醒x11不存在.一个接着安装Xquarz2.7.6. matlab它可以在本地 ...

  7. MySQL Full Join的实现

    MySQL Full Join的实现 由于MySQL不支持FULL JOIN,以下是替代方法 left join + union(可去除反复数据)+ right join select * from ...

  8. java实现xml文件CRUD

    java删除xml多个节点: 方案1.你直接改动了nodeList.这一般在做循环时是不同意直接这么做的. 你能够尝试在遍历一个list时,在循环体同一时候删除list里的内容,你会得到一个异常.建议 ...

  9. Codeforces Round #191 (Div. 2) D. Block Tower

    D. Block Tower time limit per test 2 seconds memory limit per test 256 megabytes input standard inpu ...

  10. Tuxedo入门学�

    中间件介绍: 介于客户机和server之间的夹层,突破了传统的c/s架构,为构建大规模,高性能,分布式c/s应用程序提供了通信,事物,安全,容错等基础服务,屏蔽了底层应用细节,应用程序不必从底层开发, ...