Ibatis,Spring整合(注解方式注入)

2024-06-21 00:48

本文主要是介绍Ibatis,Spring整合(注解方式注入),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

applicationContext.xml

复制代码
  
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"xmlns:context="http://www.springframework.org/schema/context"xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsdhttp://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx-2.5.xsdhttp://www.springframework.org/schema/aophttp://www.springframework.org/schema/aop/spring-aop-2.5.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd"><!-- 自动扫描Bean --><context:component-scan base-package="com.tq365"/><!-- 强制使用CGLIB代理 --><aop:aspectj-autoproxy proxy-target-class="true"/><!-- DataSource数据源 --><bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"destroy-method="close"><property name="driverClassName"><value>com.mysql.jdbc.Driver</value></property><property name="url"><value>jdbc:mysql://localhost:3306/ibatisorm</value></property><property name="username"><value>root</value></property><property name="password"><value>root</value></property></bean><!-- Spring iBatis SqlMapClient --><bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean"><property name="configLocation" value="WEB-INF/sqlmap-config.xml" /><property name="dataSource" ref="dataSource" /></bean><!--事务管理DataSourceTransactionManager--><bean id="txManager"class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource" /></bean><!--启动spring注解功能--><tx:annotation-driven transaction-manager="txManager" /><aop:config><aop:pointcut id="baseServiceMethods" expression="execution(* com.tq365.samples.ibatis.dao.*.*(..))" /><aop:advisor advice-ref="txAdvice" pointcut-ref="baseServiceMethods" /></aop:config><aop:aspectj-autoproxy /><tx:advice id="txAdvice" transaction-manager="txManager"><tx:attributes><tx:method name="select*" read-only="true" propagation="REQUIRED" /><tx:method name="find*" read-only="true" propagation="REQUIRED" /><tx:method name="save*" propagation="REQUIRED" isolation="REPEATABLE_READ" /><tx:method name="update*" propagation="REQUIRED" isolation="REPEATABLE_READ" /><!-- <tx:method name="add*" propagation="REQUIRED" isolation="REPEATABLE_READ" />--><tx:method name="delete*" propagation="REQUIRED" isolation="REPEATABLE_READ" /></tx:attributes></tx:advice> </beans>
复制代码

sqlmap-config.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><sqlMap resource="com/tq365/sqlMap/User.xml"/></sqlMapConfig>
复制代码

User.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"> <sqlMap namespace="User"><typeAlias alias="User" type="com.tq365.samples.ibatis.model.User"/><resultMap id="UserResult" class="User"><result property="id" column="id"/><result property="username" column="username"/><result property="address" column="address"/><result property="userpwd" column="userpwd"/></resultMap><insert id="addUser">insert user(username,userpwd,address)values(#username#,#userpwd#,#address#)</insert>  <select id="findUser" resultMap="UserResult">select * from user WHERE username=#username# and userpwd=#userpwd#</select><select id="findUserById" resultMap="UserResult">select * from user WHERE id=#id#</select> <!-- User表内记录总条数 --><select id="getTotalCount" resultClass="int">select count(*) from user</select><select id="findAllPageUser" resultMap="UserResult">select * from user limit #start#,5 </select> </sqlMap>
复制代码

UserDAO.java接口 

复制代码
  
 package com.tq365.samples.ibatis.dao;import org.springframework.stereotype.Repository;import com.tq365.samples.ibatis.model.User; import com.tq365.sqmples.util.Pages;/*** UserDAO 接口*/ @Repository public interface UserDAO {/*** 通过ID查询* @param id* @return*/public User findUserById(int id);/*** 通过ID删除* @param id*/public void deleteUserById(int id);public void addUser(User user);/*** 查询指定的User对象* @param user* @return*/public User findUser(User user); /*** 通过用户名分页查询* @param username* @return*/public Pages<User> findUsersByUsername(String username,int pageNo);/*** 所有User对象分页* @param pageNo* @return*/public Pages<User> findAllPageUser(int pageNo);}
复制代码

BaseDao.java 

复制代码
  
 package com.tq365.samples.ibatis.dao;import javax.annotation.PostConstruct; import javax.annotation.Resource;import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;import com.ibatis.sqlmap.client.SqlMapClient;/*** BaseDao,Dao需继承此Dao* @author archie2010* since 2011-3-3 下午02:52:36*/ public class BaseDao extends SqlMapClientDaoSupport{@Resource(name = "sqlMapClient")private SqlMapClient sqlMapClient;@PostConstructpublic void initSqlMapClient(){super.setSqlMapClient(sqlMapClient);} }
复制代码

  

@PostConstruct注解 
    在方法上加上注解@PostConstruct,这个方法就会在Bean初始化之后被Spring容器执行(注:Bean初始化包括,实例化Bean,并 装配Bean的属性(依赖注入))。它的一个典型的应用场景是,当你需要往Bean里注入一个其父类中定义的属性,而你又无法复写父类的属性或属性的 setter方法时

UserDAOimpl.java 

复制代码
  
 package com.tq365.samples.ibatis.dao;import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map;import org.springframework.stereotype.Component;import com.tq365.samples.ibatis.model.User; import com.tq365.sqmples.util.Pages;/*** UserDAO接口实现类* @author archie2010* since 2011-3-3 下午02:54:57*/ @Component("userDAO") public class UserDAOimpl extends BaseDao implements UserDAO{public User findUserById(int id){return (User) getSqlMapClientTemplate().queryForObject("findUserById", id);}/*** 添加User*/public void addUser(User user) {getSqlMapClientTemplate().insert("addUser", user);}/*** 删除User*/public void deleteUserById(int id) {getSqlMapClientTemplate().delete("deleteUserById", id);}/*** 查找User*/public User findUser(User user) {return (User) getSqlMapClientTemplate().queryForObject("findUser", user);}public int getTotalCountByUsername(String username){return (Integer) getSqlMapClientTemplate().queryForObject("getTotalCountByUsername", username);}/*** User分页*/@SuppressWarnings("unchecked")public Pages<User> findUsersByUsername(String username,int pageNo) {Pages<User> pages=new Pages<User>(getTotalCountByUsername(username));pages.setPageSize(5);List<User> userList=new ArrayList<User>();Map<String, Object> map=new HashMap<String, Object>();map.put("username", username);map.put("start", pages.getStart(pageNo));userList=(List<User>) getSqlMapClientTemplate().queryForObject("findUsersByUsername", map);pages.setPageList(userList);return pages;}/*** 查询所有记录* @return*/public int getTotalCount(){return (Integer) getSqlMapClientTemplate().queryForObject("getTotalCount");}@SuppressWarnings("unchecked")public Pages<User> findAllPageUser(int pageNo){Pages<User> pages=new Pages<User>(getTotalCount());pages.setPageSize(5);List<User> userList=new ArrayList<User>();userList=(List<User>) getSqlMapClientTemplate().queryForList("findAllPageUser", pages.getStart(pageNo));pages.setPageList(userList);return pages;}}

这篇关于Ibatis,Spring整合(注解方式注入)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1079735

相关文章

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

Docker镜像修改hosts及dockerfile修改hosts文件的实现方式

《Docker镜像修改hosts及dockerfile修改hosts文件的实现方式》:本文主要介绍Docker镜像修改hosts及dockerfile修改hosts文件的实现方式,具有很好的参考价... 目录docker镜像修改hosts及dockerfile修改hosts文件准备 dockerfile 文

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进

Win11安装PostgreSQL数据库的两种方式详细步骤

《Win11安装PostgreSQL数据库的两种方式详细步骤》PostgreSQL是备受业界青睐的关系型数据库,尤其是在地理空间和移动领域,:本文主要介绍Win11安装PostgreSQL数据库的... 目录一、exe文件安装 (推荐)下载安装包1. 选择操作系统2. 跳转到EDB(PostgreSQL 的

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、