以前使用iBATIS时,DAO类,需要先定义一个接口,再定义一个Impl类,然后,每个方法里差不多都是一两句话的事。现在,我把DAO直接去掉了,完全用iBATIS来充当DAO,借助于Spring的注解,将iBATIS的DB操作对象直接注入Service中,而且什么也不用继承和实现,单纯的Java类一个。如果使用的是Struts2,一个Action一个Service就可以了,都是单纯的Java类,什么都不继承,什么也不实现。
具体如下:
1、在applicationContext.xml中,添点东西。
① beans标签中增加【xmlns:context="http://www.springframework.org/schema/context"】声明。
Xml代码如下:
<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:jee="http://www.springframework.org/schema/jee"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-2.5.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd"
default-lazy-init="true">
② 增加annotation自动注册Bean的声明。
<!-- 使用annotation 自动注册bean,并检查@Required,@Autowired的属性已被注入 -->
<context:component-scan base-package="需要自动注册的包名" />
③ iBATIS部分的配置
Xml代码如下:
<!-- Spring的iBatis 配置 -->
<bean id="sqlMapClientTemplate" class="org.springframework.orm.ibatis.SqlMapClientTemplate">
<constructor-arg>
<ref bean="sqlMapClient"></ref>
</constructor-arg>
</bean>
<bean id="sqlMapClient"
class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
<property name="configLocation"
value="WEB-INF/SqlMapConfig.xml" />
<property name="dataSource" ref="dataSource" />
</bean>
注:①②,可以Google下;③是关键,这样就搞出一个被注好的sqlMapClientTemplate对象,可以用它来操作数据库了。
2、Service类,什么也不用继承或实现。
代码截段如下:
Java代码如下:
@Service
public class BookmarkService {
/** iBATIS的DB操作辅助类对象 */
@Autowired
private SqlMapClientTemplate sqlMapClientTemplate;
// 注:不需要set/get方法,自动注入
.....
/**
* 查询基本书签.<br />
*
* @param mapBean
* @return
*/
public List searchBookmarkBaseList(Map mapBean) {
return sqlMapClientTemplate.queryForList("Bookmark.searchBookmarkBaseList", mapBean);
}
}
通过上面的搞法,就完全可以不用再整出一个如:public class UserDaoImpl extends SqlMapClientDaoSupport implements UserDao {...}这样写法的Impl类了,当然也省了那个接口(这种接口总是想的挺好,往往鸡肋一堆),当然进行DB操作时,更不需要使用那个实在太别扭的:getSqlMapClientTemplate().queryForObject(...)写法了。
相关推荐
Ibatis,另一方面,是一个SQL映射框架,它允许开发者将SQL查询直接写在XML配置文件中,与Java对象进行映射,从而避免了传统的JDBC代码的繁琐。Spring框架是Java应用开发中的核心组件,提供了依赖注入、面向切面编程...
Ibatis是一款轻量级的Java持久层框架,它允许开发者将SQL语句直接写在配置文件中,实现了数据库操作与业务逻辑的解耦。这款插件的主要作用是为Eclipse提供自动化工具,帮助开发者快速生成DAO(数据访问对象)和服务...
iBATIS是一个优秀的Java持久层框架,它提供了一个SQL映射框架,使开发者能够将SQL语句直接写在配置文件中,与Java代码分离,从而实现了数据访问逻辑和业务逻辑的解耦。"ibatis2.rar"这个压缩包文件包含了关于iBATIS ...
Ibatis,一个优秀的持久层框架,它允许开发者将SQL语句直接写在配置文件中,避免了JDBC的繁琐代码,提升了开发效率。接下来,我们将深入探讨IbatisDemo中的关键知识点。 一、Ibatis框架简介 Ibatis是由MyBatis团队...
4. **Service层**:这一层负责业务逻辑的处理,通常会调用Mapper接口来执行数据库操作。 5. **DAO层**:数据访问对象,直接与数据库交互,实现了Mapper接口中的方法。 6. **实体类**:Java对象,用于映射数据库中...
而iBatis则是一个SQL映射框架,它允许开发者将SQL语句直接写在配置文件中,从而简化了数据库访问的复杂性。 整合Spring和iBatis,可以充分利用两者的优势,实现灵活、高效的数据库访问。以下是整合过程中的关键知识...
- **概念**:iBatis是一个SQL映射框架,允许开发者将SQL语句直接写在XML配置文件中,与Java代码解耦。 - **主要优势**:灵活的SQL编写、避免了过多的JDBC代码、自动结果映射。 - **基本结构**:SqlSessionFactory...
iBATIS,全称为“Infrastructure As A Business Logic Translation Service”,是一个优秀的开源持久层框架,它允许开发者将SQL语句直接写在Java代码中,解决了Java与数据库交互时的繁杂工作,提供了半封装的数据...
2. **动态SQL**:Ibatis允许在XML映射文件中直接编写条件语句,如`<if>`、`<choose>`、`<when>`、`<otherwise>`等标签,实现SQL的动态拼接,增加了灵活性。 3. **Mapper接口**:Ibatis提供Mapper接口方式,可以将...
iBatis 是一款著名的开源持久层框架,它允许开发者将SQL语句直接写在XML配置文件中,提供了灵活的数据库交互方式,避免了过多的JDBC代码和手动设置参数以及获取结果集。在这个"iBatis Web用法实例"中,我们将深入...
Ibatis是一个优秀的持久层框架,它允许开发者将SQL语句直接写在配置文件中,避免了传统JavaEE开发中大量繁琐的JDBC代码。Ibatis通过Mapper接口和XML配置文件,实现了SQL与Java代码的分离,使得SQL的编写更加灵活,...
Ibatis是由Clinton Begin创建的一个SQL映射框架,它允许开发者将SQL语句直接写在配置文件中,通过Java接口与数据库进行交互,从而避免了传统的JDBC代码编写,降低了开发复杂性。Ibatis提供动态SQL和事务管理等功能,...
iBatis允许开发者将SQL语句写在XML配置文件中,这些SQL语句可以直接与Java对象进行映射,实现了SQL语句和业务逻辑的解耦。iBatis的主要特点包括动态SQL、事务管理、结果集映射和缓存机制。 **Struts2与iBatis整合**...
1. **SQL调优**:Ibatis允许直接编写原生的SQL,便于充分利用Oracle的特性进行性能优化。 2. **事务管理**:Ibatis提供了对数据库事务的控制,可以配合Oracle的ACID特性处理复杂的事务场景。 3. **存储过程调用**...
通过MyBatis-Spring等扩展,可以直接在Service层注入Mapper接口,简化调用。 4. ParameterMapping和ResultMapping:它们分别负责参数和结果的映射,确保Java对象与数据库记录之间的转换顺利进行。 5. 动态SQL:...
而iBatis则是一个轻量级的SQL映射框架,它简化了数据库操作,使得开发者能更直接地控制SQL语句。 **SpringMVC整合iBatis的核心概念:** 1. **SpringMVC**:SpringMVC是Spring框架的一部分,用于构建Web应用的模型-...
1. **简洁**: 与 Hibernate 等全自动化 ORM 框架相比,Ibatis 保持了 SQL 的灵活性,开发者可以直接编写 SQL,满足复杂的查询需求。 2. **高性能**: 由于 SQL 控制权在开发者手中,可以根据数据库特性优化 SQL,...
Ibatis是一个轻量级的Java持久层框架,它允许开发者将SQL语句直接写在配置文件中,与传统的JDBC相比,提供了更加灵活和易于维护的解决方案。 Ibatis的主要优点包括: 1. **简化JDBC代码**:Ibatis通过XML或注解...
iBatis则作为数据访问层,它允许开发者在XML配置文件中编写SQL语句,而不是直接在Java代码中硬编码。这提高了代码的可读性和可维护性。在登录场景下,iBatis将用于从数据库查询用户信息,比对输入的用户名和密码是否...