对于一个粗学者而言一言概况就是:ibatis非常简单易学,hibernate相对较复杂,门槛较高。
但是,hibernate对数据库结构提供了较为完整的封装,hibernate的o/r mapping实现了pojo 和数据库表之间的映射,以及sql 的自动生成和执行。程序员往往只需定义好了pojo 到数据库表的映射关系,即可通过hibernate 提供的方法完成持久层操作。程序员甚至不需要对sql 的熟练掌握, hibernate/ojb 会根据制定的存储逻辑,自动生成对应的sql 并调用jdbc 接口加以执行。 hibernate把数据库和你隔离了,你不需要关注数据库是mysql还是oracle,hibernate来帮你生成查询的sql。但问题也来了,如果你就要用某种数据库特有的功能,或者你就要让查询的sql完全符合你的心意,这就难了。
因为hibernate则基本上可以自动生成,偶尔会写一些hql。同样的需求,ibatis的工作量比hibernate要大很多。类似的,如果涉及到数据库字段的修改,hibernate修改的地方很少,而ibatis要把那些sql mapping的地方一一修改。而且,从文档的丰富性,产品的完善性,版本的开发速度都要强于ibatis。
众所周知,web开发,性能瓶颈在数据库。比如12306,我觉得瓶颈还是在数据库。
系统数据处理量巨大,性能要求极为苛刻,这往往意味着我们必须通过经过高度优化的sql语句(或存储过程)才能达到系统性能设计指标。在这种情况下ibatis会有更好的可控性和表现。 具体参考《Hibernate与Ibatis比较》——ibatis原理浅析
对于我个人来说,我首选ibatis。比如之前写jsp,我就坚决不屑于JSTL,你可以用intelliJ idea 智能提示快速开发。至于hql,shift……
二者配置都差不多!无非就是:
这里科普下IBatis的详细配置及使用情况!节选自赵四的:iBatis开发的一个应用
下面是ibatis全局的文件:SqlMapConfig.xml:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN"
"http://ibatis.apache.org/dtd/sql-map-config-2.dtd">
<sqlMapConfig>
<!-- 配置数据库连接 -->
<transactionManager type="JDBC" commitRequired="false">
<dataSource type="SIMPLE">
<property name="JDBC.Driver" value="com.mysql.jdbc.Driver"/>
<property name="JDBC.ConnectionURL" value="jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8"/>
<property name="JDBC.Username" value="root"/>
<property name="JDBC.Password" value="jiangwei"/>
<property name="Pool.MaximumActiveConnections" value="10" />
<property name="Pool.MaximumIdleConnections" value="5" />
<property name="Pool.MaximumCheckoutTime" value="120000" />
<property name="Pool.TimeToWait" value="500" />
<property name="Pool.PingQuery" value="select 1 from account" />
<property name="Pool.PingEnabled" value="false" />
<property name="Pool.PingConnectionsOlderThan" value="1" />
<property name="Pool.PingConnectionsNotUsedFor" value="1" />
</dataSource>
</transactionManager>
<!-- 配置SQL查询的配置文件的Account.xml -->
<sqlMap resource="/Account.xml"/>
</sqlMapConfig>
对于上面的数据源配置的参数说明:
再看看Hibernate配置文件
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory name="foo">
<!-- 1. 配置数据库信息 -->
<!-- 方言(连接的数据库类型) -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="connection.url">jdbc:mysql:///hibernate_20160926</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.username">root</property>
<property name="connection.password">yezi</property>
<!-- 2. 其他配置 -->
<!-- 显示生成的SQL语句 -->
<property name="hibernate.show_sql">true</property>
<!-- 3. 导入映射文件 -->
<mapping resource="cn/itcast/a_helloworld/User.hbm.xml" />
</session-factory>
</hibernate-configuration>
这里只是参考对比下而已,没有必要较真!
第二步,配置映射文件:
<?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">
<sqlMap namespace="Account">//命名空间
<!-- 给Account实体类起一个别名 -->
<typeAlias alias="Account" type="com.ibatis.demo.domain.Account"/>
<!-- 将Account实体类中的属性和mysql中的account表中的字段对应起来 -->
<resultMap id="AccountResult" class="Account">
<result property="id" column="_id"/>
<result property="firstName" column="first_name"/>
<result property="lastName" column="last_name"/>
<result property="emailAddress" column="emall"/>
</resultMap>
<!-- 查询account表中所有数据,其中id是这条查询语句的id号,在代码中用到,具有唯一性 -->
<select id="selectAllAccounts" resultMap="AccountResult">
select * from account
</select>
<!-- 通过id来查询account表中的数据 -->
<select id="selectAccountById" parameterClass="int" resultClass="Account">
select
id as _id,
first_name as firstName,
last_name as lastName,
emall as emailAddress
from account
where _id = #id#
</select>
<!--插入语句-->
<insert id="insertAccount" parameterClass="Account">
insert into accout (
_id,
first_name,
last_name,
emall
values (
#id#, #firstName#, #lastName#, #emailAddress#
)
</insert>
<!-- 更新语句 -->
<update id="updateAccount" parameterClass="Account">
update account set
first_name = #firstName#,
last_name = #lastName#,
emall = #emailAddress#
where
_id = #id#
</update>
<!-- 删除语句 -->
<delete id="deleteAccountById" parameterClass="int">
delete from account where _id = #id#
</delete>
</sqlMap>
hibernate的:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="cn.itcast.a_helloworld">
<class name="account" table="account">
<id name="id" type="int" column="id">
<generator class="native"/>
</id>
<property name="firstName" type="string" column="first_name" />
<property name="lastName" type="string" column="last_name" />
<property name="emailAddress" type="string" column="emall" />
</class>
</hibernate-mapping>
创建实体类,其实就是javaBean,没有什么好说的。
再看看iBatis访问数据的类:
package com.ibatis.demo.data;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;
import com.ibatis.common.resources.Resources;
import com.ibatis.demo.domain.Account;
import java.io.Reader;
import java.io.IOException;
import java.util.List;
import java.sql.SQLException;
public class IbaitsData {
private static SqlMapClient sqlMapper;
static {
try {
//读取iBatis的配置文件:SqlMapConfig.xml
Reader reader = Resources.getResourceAsReader("/SqlMapConfig.xml");
sqlMapper = SqlMapClientBuilder.buildSqlMapClient(reader);
reader.close();
} catch (IOException e) {
throw new RuntimeException("Something bad happened while building the SqlMapClient instance." + e, e);
}
}
//查询account表中的所有记录
@SuppressWarnings("unchecked")
public static List selectAllAccounts () throws SQLException {
return sqlMapper.queryForList("selectAllAccounts");
}
//查询account表中_id为id的记录
public static Account selectAccountById (int id) throws SQLException {
return (Account) sqlMapper.queryForObject("selectAccountById", id);
}
//插入一条记录
public static void insertAccount (Account account) throws SQLException {
sqlMapper.insert("insertAccount", account);
}
//更新一条记录
public static void updateAccount (Account account) throws SQLException {
sqlMapper.update("updateAccount", account);
}
//删除一条记录
public static void deleteAccount (int id) throws SQLException {
sqlMapper.delete("deleteAccount", id);
}
}
但是,到这里就不想再对比了。个人觉得ibatis比hibernate简单。毕竟写slq就可以了。
下面是Ibatis项目结构图!
参考文章:
【SSH进阶之路】Hibernate搭建开发环境+简单实例(二)
文章内容如有侵权,请告知以悉删除,谢谢!
旧调重弹Hibernate与Ibatis区别--深入架构设计 - java连接数据库 - 周陆军的个人网站
转载注明来源。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。