我们现在用的数据访问组件封装了IBatis.Net框架,提供了标准的数据访问接口和服务。正好总结一下老技术IBatis.Net
在进行实际的数据访问开发之前,我们先了解一下:IBatis.Net中几个重要的配置文件和一些关键的技术原理:
4个重要的配置文件:

  1. Providers.config:数据库连接驱动配置文件,我们主要用SQLServer数据库连接驱动
  2. Mapper.xml,例如: DataPermissions.xml,定义SQL语句和结果集映射关系。
  3. SqlMap.config:统一管理数据库连接驱动、连接信息、Mapper文件列表
  4. Database_***.Config文件:存储数据库的连接信息

关键的技术特性

  1. IBatis是一个半自动化的ORM框架,支持多种业界主流的数据库,支持开发人员写SQL,这样开发人员就可以写出尽可能优化的SQL
  2. SqlMapper文件中主要包含alias类别名,ResultMaps结果集映射,Statements各类SQL语句
  3. SqlMapper文件中,实体类的属性对应ResultMap中的Property,实体类的属性同时对应数据库表中的Column
  4. IBatis中的SqlMapper文件中,#代表SQL绑定;$代表SQL拼接,有SQL注入风险,不建议使用
  5. 基于Castle的代理类技术,支持Dao接口,Dao接口中的方法必须和SqlMapper文件中的SqlID保持一致。这样DaoService在构造Dao接口的代理实现类时才可以定位到指定的SQL,然后执行。
  6. 支持批量SQL操作,例如Insert、Update和Delete
  7. 支持返回一对多,多对多关联结果集
  8. 支持数据库事务
  9. 支持数据缓存:全局缓存和会话缓存

开发一个数据访问的业务功能,主要有以下4个步骤:

  1. 梳理好业务需求,定义接口;
  2. 定义IBatis Mapper文件,根据接口的方法一一实现SQL语句;
  3. 设置好数据库连接,将IBatis Mapper文件的路径添加到SqlMap配置文件中;
  4. 调用DaoService,获取接口的实现,访问数据库。

示例几个关键的写法
1. 一对多关系,批量Insert

   <insert id="SaveDomainModel" parameterClass="DomainModel">
begin
INSERT INTO Meta_DomainModel(ID,Name,RootDomainObjectID, IsCache, CacheStrategy, IsLogicallyDeleted, DataLoaderConfig, Version,Creator,LastModifier)VALUES(
#ID#,#Name#,#RootDomainObjectID#,#IsCache:VarChar#,#CacheStrategy#,#IsLogicDelete:VarChar#,#DataLoaderConfig#,#Version#,#Creator#,#LastModifier#)
<iterate conjunction=" " open="" close="" property="DomainObjects">
INSERT INTO Meta_DomainObject(ID,Name,DomainModelID,IsRootObject,ParentObjectID,ClazzReflectType,PropertyName,IsLazyLoad,DataObjectID,Creator,LastModifier)
VALUES(#DomainObjects[].ID#,#DomainObjects[].Name#,#DomainObjects[].DomainModelID#,#DomainObjects[].IsRootObject:VarChar#,#DomainObjects[].ParentObjectID#,#DomainObjects[].ClazzReflectType#,
#DomainObjects[].PropertyName#,#DomainObjects[].IsLazyLoad:VarChar#,#DomainObjects[].DataObjectID#,#DomainObjects[].Creator#,#DomainObjects[].LastModifier#)
</iterate>
end;
</insert>

2. 简单批量Insert插入

     <insert id="SaveDomainObjectElements" parameterClass="ArrayList">
begin
<iterate conjunction=" " open="" close="" >
INSERT INTO Meta_DomainObjectElement(ID,Name,Alias,DisplayName,DomainObjectID,DataType,Length,Precision,DefaultValue,IsAllowNull,ElementType,DataColumnID,
PropertyType,PropertyName,IsForQuery,Creator,LastModifier)
VALUES(#[].ID#,#[].Name#,#[].Alias#,#[].DisplayName#,#[].DomainObjectID#,#[].DataType#,#[].Length#,#[].Precision#,#[].DefaultValue#,#[].IsAllowNull:VarChar#,#[].ElementType#,#[].DataColumnID#,
#[].PropertyType#,#[].PropertyName#,#[].IsForQuery:VarChar#,#[].Creator#,#[].LastModifier#)
</iterate>
end;
</insert>

3. 查询一对多结果集

   <resultMap id="DataObjectResultMap" class="DataObject" groupby="ID">
<result property="ID" column="ID" />
<result property="Name" column="Name" />
<result property="Descriptions" column="Descriptions" />
<result property="DataSourceName" column="DataSourceName" />
<result property="LogicTableName" column="LogicTableName" />
<result property="IsTableSharding" column="IsTableSharding" />
<result property="IsDatabaseSharding" column="IsDatabaseSharding" />
<result property="TableShardingStrategyID" column="TableShardingStrategy" />
<result property="DatabaseShardingStrategyID" column="DatabaseShardingStrategy" />
<result property="IsView" column="IsView" />
<result property="IsLogicallyDeleted" column="IsLogicallyDeleted" />
<result property="Version" column="Version" />
<result property="Columns" resultMapping="MetadataMapper.DataColumnResultMap"></result>
<result property="Creator" column="Creator" />
<result property="CreateTime" column="CreateTime" />
<result property="LastModifier" column="LastModifier" />
<result property="LastModifyTime" column="LastModifyTime" />
</resultMap>
<resultMap id="DataColumnResultMap" class="DataColumn">
<result property="ID" column="C_ID" />
<result property="ColumnName" column="ColumnName" />
<result property="DisplayName" column="DisplayName" />
<result property="DataObjectID" column="DataObjectID" />
<result property="DataTypeID" column="DataType" />
<result property="Length" column="Length" />
<result property="Precision" column="Precision" />
<result property="DefaultValue" column="DefaultValue" />
<result property="IsNullable" column="IsNullable" />
<result property="IsPkColumn" column="IsPkColumn" />
<result property="IsSystem" column="IsSystem" />
<result property="IsShardingColumn" column="IsShardingColumn" />
<result property="ColumnOrder" column="ColumnOrder" />
<result property="Creator" column="C_Creator" />
<result property="CreateTime" column="C_CreateTime" />
<result property="LastModifier" column="C_LastModifier" />
<result property="LastModifyTime" column="C_LastModifyTime" />
</resultMap>

对应的Select 语句

     <select id="GetDataObject" resultMap="DataObjectResultMap" parameterClass="string">
SELECT Meta_DataObject.ID,Meta_DataObject.Name,Descriptions, DataSourceName, LogicTableName, IsTableSharding, IsDatabaseSharding, TableShardingStrategy,DatabaseShardingStrategy,IsView,IsLogicallyDeleted,Version,Meta_DataObjectColumn.Creator,Meta_DataObjectColumn.LastModifier,Meta_DataObjectColumn.CreateTime,Meta_DataObjectColumn.LastModifyTime,
Meta_DataObjectColumn.ID as C_ID,ColumnName,DisplayName,DataObjectID,DataType,Length,Precision,DefaultValue,IsNullable,IsPkColumn,IsShardingColumn,IsSystem,ColumnOrder,
Meta_DataObjectColumn.Creator as C_Creator,Meta_DataObjectColumn.LastModifier as C_LastModifier,Meta_DataObjectColumn.CreateTime as C_CreateTime,Meta_DataObjectColumn.LastModifyTime as C_LastModifyTime
FROM Meta_DataObject
LEFT JOIN Meta_DataObjectColumn on Meta_DataObjectColumn.DataObjectID = Meta_DataObject.ID
WHERE Meta_DataObject.ID=#id#
</select>

4. 批量删除多张表

    <delete id="DeleteShardingStrategy" parameterClass="string">
begin
DELETE FROM Meta_ShardingColumn WHERE ShardingStrategyID=#id#
DELETE FROM Meta_ShardingStrategy WHERE ID=#id#
end;
</delete>

5. 删除指定数据

  <delete id="DeleteShardingColumns" parameterClass="string">
DELETE FROM Meta_ShardingColumn WHERE DataObjectID=#id#
</delete>

6. 查询数据行数

 <select id="IsTaskExist" resultClass="int" parameterClass="string">
SELECT COUNT(1) FROM TableTask WHERE name=#Name#
</select>

以上就是一些简单的IBatis.Net总结。

周国庆

2017/10/14

IBatis.Net 老技术新研究的更多相关文章

  1. 老技术新谈,Java应用监控利器JMX(2)

    各位坐稳扶好,我们要开车了.不过在开车之前,我们还是例行回顾一下上期分享的要点. 上期由于架不住来自于程序员内心的灵魂的拷问,于是我们潜心修炼,与 Java 应用监控利器 JMX 正式打了个照面. J ...

  2. 老技术新谈,Java应用监控利器JMX(3)

    各位坐稳扶好,我们要开车了.不过在开车之前,我们还是例行回顾一下上期分享的要点. 上期我们深入的聊了聊 JMX,把 JMX 的架构了解了七七八八,最后通过代码实战,解决系列疑问,实现远程动态修改应用参 ...

  3. 老技术新谈,Java应用监控利器JMX(1)

    先聊聊最近比较流行的梗,来一次灵魂八问. 配钥匙师傅: 你配吗? 食堂阿姨: 你要饭吗? 算命先生: 你算什么东西? 快递小哥: 你是什么东西? 上海垃圾分拣阿姨: 你是什么垃圾? 滴滴司机: 你搞清 ...

  4. .Net2.0 --Winform结合WebBrowser控件和Socket老技术来实现另类Push~

    原文:.Net2.0 --Winform结合WebBrowser控件和Socket老技术来实现另类Push~ 目前的企业级开发比较流行的是Web2.0技术,但是由于Web技术基于请求--响应的交互模式 ...

  5. [转载]《民航科技》2012年4月专家论坛:罗喜伶《SWIM技术国际研究动态及对中国民航的借鉴意义》

    专家介绍:罗喜伶,北京航空航天大学电子信息工程学院副教授,工学博士,硕士生导师,国家空管新航行系统技术重点实验室和协同式网络化空中交通管理系统研究教育部创新团队核心成员,民航空管广域信息系统专家组成员 ...

  6. 基于802.11Fuzz技术的研究

    转自安全客 关于无线的Fuzz最开始接触了解时,国内基本毛线都搜不到.经过几个月的资料搜集和学习,将大约全网的fuzz资料整理翻译分析并读懂写下,就为填补国内空白,也希望无线爱好者能多多交流. 在各个 ...

  7. 老梗新玩「GitHub 热点速览 v.22.34」

    作者:HelloGitHub-小鱼干 不知道你是否和我有一样的烦恼,最近的流行梗当自己要用拿来造词时,就陷入了不知道咋"换壳"的尴尬地步.sao-gen-gen 大大减少了你老梗新 ...

  8. 基于SURF特征的图像与视频拼接技术的研究和实现(一)

    基于SURF特征的图像与视频拼接技术的研究和实现(一)      一直有计划研究实时图像拼接,但是直到最近拜读西电2013年张亚娟的<基于SURF特征的图像与视频拼接技术的研究和实现>,条 ...

  9. Hinton等人新研究:如何更好地测量神经网络表示相似性

    Hinton等人新研究:如何更好地测量神经网络表示相似性 2019年05月22日 08:39:15 喜欢打酱油的老鸟 阅读数 177更多 分类专栏: 人工智能   https://www.toutia ...

随机推荐

  1. grunt之filerev、usemin

    窃以为这两个插件是比较有用的,filerev是给js.css进行编码重命名,usemin修改html中被重命名的js.css文件的引用.另外说明下之前将concat.cssmin.uglify放在一篇 ...

  2. NHibernate教程(20)——二级缓存(上)

    本节内容 引入 介绍NHibernate二级缓存 NHibernate二级缓存提供程序 实现NHibernate二级缓存 结语 引入 上一篇我介绍了NHibernate内置的一级缓存即ISession ...

  3. jQuery插件——ajax

    一.ajax请求 1.load(url, [data], [callback]) 概述:加载远程的HTML文件代码,并插入到指定的DOM节点中. 参数:url:待装入 HTML 网页网址. data: ...

  4. 【★】微信之于QQ的市场哲学

    2016年的移动app下载排行榜出炉后,我们惊奇发现,前十名中有6个应用软件来自腾讯公司.而前两名毋庸置疑是远远碾压第三名的微信与qq.这让我们看到社交app的重要性的同时也回到了那个原始的问题:腾讯 ...

  5. 2015211230108《Java程序设计》第10周学习总结

    1. 本周学习总结 2. 书面作业 Q1.finally 题目4-2 1.1 截图你的提交结果(出现学号) 1.2 4-2中finally中捕获异常需要注意什么? finally的作用: 1.确定程序 ...

  6. [03] Servlet继承关系和生命周期

    1.Servlet的继承关系 假如现有我们自定义的一个Servlet,继承HttpServlet,那么实际上它的继承链如下图:   可以看到,核心的部分在于: 两个顶级接口 Servlet Servl ...

  7. 对Spring IOC的理解(转)

    Ioc—Inversion of Control,即“控制反转”,不是什么技术,而是一种设计思想.在Java开发中,Ioc意味着将你设计好的对象交给容器控制,而不是传统的在你的对象内部直接控制.如何理 ...

  8. JMeter关联(正则表达式提取器)

    关联:与系统交互过程中,系统返回的内容,需要在接下来的交互中用到,如防止csrf攻击而生成的token. 从前一个请求中取,用Regular Expression Extractor 正则表达式提取器 ...

  9. Spring c3p0连接池无法释放解决方案

    通过c3p0配置连接池的时候,在进行压力测试的时候,日志出现了这样一个错误:Data source rejected establishment of connection, message from ...

  10. 【个人笔记】《知了堂》MySQL三种关系:一对一,一对多,多对多。

    一对一:比如一个学生对应一个身份证号.学生档案: 一对多:一个班可以有很多学生,但是一个学生只能在一个班: 多对多:一个班可以有很多学生,学生也可以有很多课程: 一对多关系处理: 我们以学生和班级之间 ...