ibatis 开发中的经验 (一)ibatis 和hibernate 在开发中的理解

时间:2022-09-04 12:20:26

这个项目的底层是用ibatis框架完毕,这几天也是都在用这个框架写代码,也有了一些简单的理解,把项目拿过来后基本的配置都已经配置好了,比方一些事务、日志控制等,在开发中主要用到的是写SQL语句以及熟悉ibatis xml文件都提供的一些标签,这些标签大部分是用来处理推断、逻辑,使得sql能够动态组装变的更灵活。

在写代码的工作量上ibatis要比hibernate高一些,在你写了服务层后还须要些dao层,dao层实现,然后这些在hibernate中不须要自己写,仅仅写到服务层就能够调用hibernate提供的对象直接操纵数据,利用hibernate自己封装的一些方法完毕数据库的增删该茶,hibernate是从java实体类映射到了数据库表,我们调用它提供的方法就能够完毕操作数据库,sql语句会更具调用了它的什么方法自己主动生成,ibatis是封装了java实体类到sql语句,运行sql到数据还须要一个过程也是ibatis封装实现,相比开发人员写的代码是不是少了非常多呢。

什么时候使用哪一个框架更好一些?

ibatis适合在须要往一个系统里面添加新功能,可是表结构不能够修改的情况,由于ibatis在数据库操作细节上比hibernate要灵活非常多,它是面向SQL语句的框架而hibernate直接面向表结构,假设要改变表结构修改的地方会比較多。

对于高并发、非常大的数据量系统中,使用ibatis效果要比hibernate好,我们能够自己写优化效率高的sql语句和存储过程来解决高数据量问题,从眼下开发来看hibernate写出来的hsql语句不easy优化,关系越复杂效率就会越慢,当然没有什么是一成不变的hibernate也会自己支持原生SQL语句,完好自己一些不完美的地方。

在一个系统的维护上也显然易见,ibatis占有明显优势它把sql写在了配置文件中面,维护的时候假如须要改变某个查询功能,在配置文件中面改改就能够完毕,假设是hibernate就须要修改代码并又一次编译。

以下这张是ibatis原理图

ibatis 开发中的经验 (一)ibatis 和hibernate 在开发中的理解

图中左边是传入參数类型、右边是返回结构类型,中间是配置文件信息,它支持基本数据类型(int/string/boolean)以及对象、map等类型数据,用起来也比較方便。

sqlMap-Config.xml相当于hibernate.cfg.xml文件,sqlmap.xml相当于资源文件,比例如以下配置信息

举一个查询的样例:一个简单的下拉列表框查询

select载入过程

当载入select标签的时候,默认选中option子标签有selected=true的那个option,选中标签之后会把option的value属性值赋给select标签的value属性,假设option的value为空,将<option>測试</option>这两个開始和结束标签值赋给select,该实现即是利用了这个赋值过程,value值分为给了0、1、2三个值表示三种类型的查询条件。

JSP页面例如以下

	<span class="STYLE1">
请选择查询方式:
<select name="selectType" value="">
<option <%=selected=="default"? "selected=true" :"" %> value="0">按默认查询</option>
<option <%=selected=="name"? "selected=true" :"" %> value="1">按类型查询</option>
<option <%=selected=="companyname"? "selected=true" :"" %> value="2">按公司查询</option>
</select>
请输入keyword:
</span>
	<!-- Transaction manager for a single JDBC DataSource DAO IoC -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource">
<ref local="dataSource" />
</property> </bean>
<!-- Apache Database Connection Pool -->
<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName">
<value>${db.driver}</value>
</property>
<property name="url">
<value>${db.url}</value>
</property>
<property name="username">
<value>${db.user}</value>
</property>
<property name="password">
<value>${db.password}</value>
</property>
</bean> <!-- sqlMapClient for DAOIbatisImpl -->
<bean id="sqlMapClient"
class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
<property name="configLocation">
<value>classpath:sql-map-config.xml</value>
</property>
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="lobHandler" ref="lobHandler"/>
</bean>
<bean id="lobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler"/>

sqlmap.xml代码

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd"> <!--
Note: auto-generated at 2006-7-6 16:05:43.
--> <sqlMap namespace="ns"> <resultMap id="orgInfoChildId" class="com.zhjy.domain.Organization">
<result column="id" property="id" jdbcType="VARCHAR" />
<result column="parent_id" property="pid" jdbcType="VARCHAR" />
<result column="name" property="name" jdbcType="VARCHAR" />
<result column="isParent" property="isParent" jdbcType="VARCHAR" />
<result column="checked" property="checked" jdbcType="VARCHAR" />
<result column="open" property="open" jdbcType="VARCHAR" />
</resultMap>
<!-- 依据左側树查询记录语句開始 -->
<select id="ns.findContacts_count" resultClass="java.lang.Integer"
parameterClass="java.util.Map">
SELECT COUNT(ID)
FROM category,contactinfo,category_contactinfo
WHERE category.ID=category_contactinfo.CATEGORY_ID AND contactinfo.contactid=category_contactinfo.CONTACT_ID <isEqual prepend="and" property="selectType" compareValue="1">
<isNotEmpty prepend="" property="keyword">
name like '%$keyword$%'
</isNotEmpty>
</isEqual>
<isEqual prepend="and" property="selectType" compareValue="2">
<isNotEmpty prepend="" property="keyword">
companyname like '%$keyword$%'
</isNotEmpty>
</isEqual>
<isEqual prepend="and" property="selectType" compareValue="0">
<isNotEmpty prepend="" property="keyword">
(name like '%$keyword$%'
</isNotEmpty>
<isNotEmpty prepend="or" property="keyword">
companyname like '%$keyword$%')
</isNotEmpty>
</isEqual>
<isNotEmpty prepend="and" property="id">
id=#id:VARCHAR#
</isNotEmpty>
</select> </sqlMap>

这个是动态载入查询条件,以后假设新增了查询选项对应的改改配置文件就能够,不须要再修改代码里面的东西,比曾经灵活了i些。

ibatis还在使用和熟悉中……

ibatis 开发中的经验 (一)ibatis 和hibernate 在开发中的理解的更多相关文章

  1. C3P0连接池在hibernate和spring中的配置

    首先为什么要使用连接池及为什么要选择C3P0连接池,这里就不多说了,目前C3P0连接池还是比较方便.比较稳定的连接池,能与spring.hibernate等开源框架进行整合. 一.hibernate中 ...

  2. &lbrack;转载&rsqb; 根据多年经验整理的《互联网MySQL开发规范》

    原文: http://weibo.com/p/2304181380b3f180102vsg5 根据多年经验整理的<互联网MySQL开发规范> 写在前面:无规矩不成方圆.对于刚加入互联网的朋 ...

  3. Android IOS WebRTC 音视频开发总结(六)-- iOS开发之含泪经验

    前段时间在搞webrtc iOS开发,所以将标题改为了Android IOS WebRTC 音视频开发总结, 下面都是开发过程中的经验总结,转载请说明出处(博客园RTC.Blacker): 1. IO ...

  4. UML造型——使用EA时序图工具的开发实践和经验

    Enterprise Architect watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveGlhb3l3NzE=/font/5a6L5L2T/fontsiz ...

  5. 十余年软件开发经历,经验总结和程序一览(涉及Socket、WPF、vc&plus;&plus;、CAD、图像、GIS)

    前言 本文主要介绍我开发的几款软件产品,大概介绍一下功能.可以让读者了解本人的开发能力,所擅长的方面.有相关开发需求可以联系作者. 本人开发软件多年,从事的行业也多种多样:自然接触了不同的业务,开发了 ...

  6. 阿里巴巴 Kubernetes 应用管理实践中的经验与教训

    作者 | 孙健波(阿里巴巴技术专家).赵钰莹 导读:云原生时代,Kubernetes 的重要性日益凸显.然而,大多数互联网公司在 Kubernetes 上的探索并非想象中顺利,Kubernetes 自 ...

  7. 基于MVC4&plus;EasyUI的Web开发框架经验总结(6)--在页面中应用下拉列表的处理

    在很多Web界面中,我们都可以看到很多下拉列表的元素,有些是固定的,有些是动态的:有些是字典内容,有些是其他表里面的名称字段:有时候引用的是外键ID,有时候引用的是名称文本内容:正确快速使用下拉列表的 ...

  8. 【转】oracle数据库开发的一些经验积累

    1.不安装Oracle客户连接Oracle 8的方法  请将以下文件拷贝到运行文件所在目录 一.ODBC动态库 : ctl3d32.dll msvcrt40.dll odbc16gt.dll odbc ...

  9. 根据多年经验整理的《互联网MySQL开发规范》

    一.基础规范 使用 INNODB 存储引擎 表字符集使用 UTF8  所有表都需要添加注释 单表数据量建议控制在 5000W 以内 不在数据库中存储图⽚.文件等大数据 禁止在线上做数据库压力测试 禁⽌ ...

随机推荐

  1. 在Web Api中集成protobuf

    安装WebApiContrib.Formatting.ProtoBuf Install-Package WebApiContrib.Formatting.ProtoBuf 注册ProtoBufForm ...

  2. spring发布和接收定制的事件&lpar;spring事件传播&rpar;

    spring发布和接收定制的事件(spring事件传播) 2012-12-26 20:05 22111人阅读 评论(2) 收藏 举报  分类: 开源技术(如Struts/spring/Hibernat ...

  3. 如何使用NPOI 导出到excel和导入excel到数据库

    近期一直在做如何将数据库的数据导出到excel和导入excel到数据库. 首先进入官网进行下载NPOI插件(http://npoi.codeplex.com/). 我用的NPOI1.2.5稳定版. 使 ...

  4. Asp&period;Net BulletedList使用及详解

    BulletedList使用及详解   文章来源:www.cnblogs.com/xiohao/archive/2013/10/09/3359263.html BulletedList是一个让你轻松在 ...

  5. Loadrunner 在controller中运行socket脚本时报错:Abnormal termination&comma; caused by mdrv process termination 的原因和解决方法

    原因: 网上给出的可能的原因大致有两个: 1.  压力负载机器的资源不足(CPU,内存) 2.  分配内存和释放内存的语句不匹配. 并给出了一些解决方案,最开始我以为是加了IP地址的原因,不断尝试增加 ...

  6. Problem &colon; &lpar;1&period;2&period;1&rpar; Text Reverse

    #include<iostream> using namespace std; void main() { char arr[1000]; int a,n; int s,t; cin&gt ...

  7. DosBox 的 DOSBOX&period;CONF 的详细配置说

    1.首先下载 DOSbox 0.72 版.   2.下载完毕,开始安装.安装到任意目录均可.安装完毕会在开始菜单生成程序组,DOSBox.conf 文件是 DOSbox 的配置文件,保持默认配置就可 ...

  8. axios 使用post方式传递参数,后端接受不到

    参考 https://segmentfault.com/a/1190000012635783

  9. Jvm远程监控

    服务器运行新建文件 : udi.policy grant codebase "file:${java.home}/../lib/tools.jar" { permission ja ...

  10. Python&plus;Selenium学习--分页处理

    场景 我们在测试一个web 应用时,经常出现翻页的情况,下面介绍翻页场景 代码 #!/usr/bin/env python # -*- codinfg:utf-8 -*- ''' @author: J ...