我们现在用的数据访问组件封装了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. (八)、vpn-pptp部署

    中小型规模网站集群架构:VPN-PPTP : 矮哥linux运维群:93324526 前言: 你想管理机器吗? 你想更安全吗? 请安装VPN吧 部署 1.查看系统是否支持PPP [root@oldbo ...

  2. 【Alpha】第七次Daily Scrum Meeting

    GIT 一.今日站立式会议照片        二.会议内容 1.讨论送礼物的方法和对象,使功能更加完善. 2.对于程序还存在的问题提出自己的看法,尽量让功能更加的饱满. 三.燃尽图 四.遇到的困难 能 ...

  3. 201521123111《Java程序设计》第5周学习总结

    1. 本章学习总结 你对于本章知识的学习总结 1.1 尝试使用思维导图总结有关多态与接口的知识点. 1.2 可选:使用常规方法总结其他上课内容. 2. 书面作业 1.代码阅读:Child压缩包内源代码 ...

  4. 201521123047 《Java程序设计》第4周学习总结

    1. 本周学习总结 1.1 尝试使用思维导图总结有关继承的知识点. 1.2 使用常规方法总结其他上课内容. 答: - 只能有一个父类,即单继承,子类继承父类的全部成员(属性和方法),并可能有自己特有的 ...

  5. 201521123074 《Java程序设计》第3周学习总结

    1.本周学习总结 用百度脑图画了一张,点开图片全屏就可以看清楚了 脑图链接 2.书面作业 Q1.代码阅读 以下代码可否编译通过?哪里会出错?为什么?尝试改正? 如果创建3个Test1对象,有内存中有几 ...

  6. 201521123070 《JAVA程序设计》第1周学习总结

    本周学习总结 1.认识了三大平台Java SE.Java EE.Java ME. 2.认识了解了JDK,JVM与JRE,且熟悉JDK的操作并下载安装. 3.学会用博客写作业了. 书面作业 Q1.为什么 ...

  7. 201521123056 《Java程序设计》第14周学习总结

    1. 本周学习总结 2. 书面作业 1. MySQL数据库基本操作 建立数据库,将自己的姓名.学号作为一条记录插入.(截图,需出现自己的学号.姓名) 在自己建立的数据库上执行常见SQL语句(截图) 参 ...

  8. 201521123051《Java程序设计》第十周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常与多线程相关内容. 2. 书面作业 本次PTA作业题集异常.多线程 1.finally 题目4-2 1.1 截图你的提交结果(出 ...

  9. java课程设计---彩票销售管理系统

    彩票购买销售系统 1.项目git地址 https://git.oschina.net/fenm/lotterry.git 部分项目地址提交截图 项目主要功能图 团队博客链接 http://www.cn ...

  10. websphere部署 hibernate jpa & Error 500: javax/persistence/OneToOne.orphanRemoval()Z

    WebSphere 7 & Javax/Persistence/OneToMany.OrphanRemoval() Error 文章出处:http://www.mkyong.com/websp ...