mybatis与spring集成

5 篇文章 0 订阅
3 篇文章 0 订阅

今天给大家分享spring与mybatis集成,大家都知道mybatis是xml文件与java实现的半自动化实现的数据看CRUD操作的,不理解的小伙伴欢迎参考之前小编写的关于mybastis的博客 

1. 引入依赖包

<!--spring整合mybatis-->
<dependency>    
    <groupId>org.mybatis</groupId>    
    <artifactId>mybatis-spring</artifactId>    
    <version>1.3.2</version>
</dependency>

<!-- 连接池 -->
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-dbcp2</artifactId>
    <version>2.1.1</version>
</dependency>
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-pool2</artifactId>
    <version>2.4.3</version>
</dependency>

<dependency>
     <groupId>org.springframework</groupId>
     <artifactId>spring-tx</artifactId>
     <version>5.3.18</version>
 </dependency>

    <!-- ********************** aop切面包生成 ********************** -->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-aspects</artifactId>
    <version>5.3.18</version>
</dependency>

<!--spring整合mybatis-->
<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring</artifactId>
    <version>1.3.2</version>
</dependency>

2. 集成配置文件

该文件用于spring与mybatis的集成,具体配置文件及注释见的applicationContext-base.xml

1)<context:component-scan base-package="com.zking"/>:
扫描器,用注解方式注入bean,并指定查找范围:com.zking.oa及子子孙孙包,使用了该注解后,context:annotation-config注解可以省略 

2) context:annotation-config/: 注解驱动,用于激活已经在spring容器中注册过的bean上面的注解

用于激活那些已经在spring容器里注册过的bean上面的注解,使用该注解相当于传统方式

3)开启注解式事务
<tx:annotation-driven transaction-manager="transactionManager"/>: manager属性指定的是事务管理器,具体配置见课件中的完整配置文件 

3. spring整合mybatis

@Service
public class Userserviceimpl implements Iuserservice {

    @Autowired
    private Iusermapper iusermapper;

      /**
     * 分页
     * @param u
     * @param pagebean
     * @return
     */
    @Override
    public List<User> queryPagePaging(User u, PageBean pagebean) {
        /*if (pagebean != null && pagebean.isPagination()) {
            PageHelper.startPage(pagebean.getPage(), pagebean.getRows());
        }

        List<User> list = iusermapper.queryPage(u);

        if (pagebean != null && pagebean.isPagination()) {
            PageInfo info = new PageInfo(list);
            pagebean.setTotal((int) info.getTotal());
        }*/
        return iusermapper.queryPage(u);
    }


}
@Repository
public interface Iusermapper {
    /**
     * 分页
     * @param u 需要的实体
     * @return
     */
    List<User> queryPage(User u);
}

3.1 自动代理

<aop:aspectj-autoproxy/>:自动为spring容器中那些配置@aspectJ切面的bean创建代理。

 applicationContext-base.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:aop="http://www.springframework.org/schema/aop"
       xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
		http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.3.xsd">

    <!--1. 注解式开发 -->
    <!--1) 注解驱动,用于激活已经在spring容器中注册过的bean上面的注解-->
    <!--<context:annotation-config/>-->
    <!-- 2) 用注解方式注入bean,并指定查找范围:com.zking.oa及子子孙孙包,使用了该注解后,context:annotation-config注解可以省略 -->
    <context:component-scan base-package="com.zking"/>

    <!--2. 引入外置jdbc配置文件 -->
    <!-- 第一种方式
    <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="location" value="classpath:jdbc.properties"/>
    </bean>
    -->
    <!-- 第二种方式,比第一种方式更简洁,第一种方式更好理解一些 -->
    <context:property-placeholder location="classpath:jdbc.properties"/>

    <!--3. dbcp2数据库连接池配置-->
    <bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"
          destroy-method="close">
        <property name="driverClassName" value="${jdbc.driver}"/>
        <property name="url" value="${jdbc.url}"/>
        <property name="username" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>
        <!--初始连接数-->
        <property name="initialSize" value="10"/>
        <!--最大活动连接数-->
        <property name="maxTotal" value="100"/>
        <!--最大空闲连接数-->
        <property name="maxIdle" value="50"/>
        <!--最小空闲连接数-->
        <property name="minIdle" value="10"/>
        <!--设置为-1时,如果没有可用连接,连接池会一直无限期等待,直到获取到连接为止。-->
        <!--如果设置为N(毫秒),则连接池会等待N毫秒,等待不到,则抛出异常-->
        <property name="maxWaitMillis" value="-1"/>

        <!--数据库持续8H 会自动关闭 ,定时查下需要随时使用 -->
        <property name="testWhileIdle" value="true"></property>
        <property name="validationQuery" value="select 1"></property>

    </bean>

    <!--4. spring和MyBatis整合 -->
    <!--1) 创建sqlSessionFactory-->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 指定数据源 -->
        <property name="dataSource" ref="dataSource"/>
        <!-- 指定mybatis核心配置文件 -->
        <!-- <property name="configLocation" value="classpath:mybatis.cfg.xml"/>-->
        <!-- 自动扫描XxxMapping.xml文件,**表示迭代查找 -->
        <property name="mapperLocations" value="classpath:/mapper/**/*.xml"/>

        <property name="plugins">
            <list>
                <bean class="com.github.pagehelper.PageInterceptor">
                    <property name="properties">
                        <!-- config params as the following -->
                        <value>
                            helperDialect=mysql
                        </value>
                    </property>
                </bean>
            </list>
        </property>

    </bean>

    <!--2) 自动扫描com/zking/oa/**/mapper下的所有XxxMapper接口(其实就是DAO接口),并实现这些接口-->
    <!--   即可直接在程序中使用dao接口,不用再获取sqlsession对象-->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!--basePackage 属性是映射器接口文件的包路径。-->
        <!--你可以使用分号或逗号 作为分隔符设置多于一个的包路径-->
        <property name="basePackage" value="com/zking/**/mapper"/>
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
    </bean>

    <!--5. 声明式事务配置开始 -->
    <!--1) 开启自动代理 -->
    <aop:aspectj-autoproxy/>

    <!--2) 事务管理器 -->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>

    <!-- 注解式事务 -->
    <tx:annotation-driven transaction-manager="transactionManager"/>

</beans>

4.spring-test

1)依赖包

<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-test</artifactId>
    <version>${spring.version}</version>
</dependency>

2)相关的注解

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath*:ApplicationContext*.xml"})

3)在执行单元测试时,为了避免产生脏数据,可将测试单元设置成事务回滚

@Rollback(value = true|false)//true回滚事务,false提交事务
@Transactional(transactionManager = "transactionManager") 

测试示例: 

简化分页实现(环捞通知)

@Component
@Aspect
public class PageintAOP {

    @Around("execution(* com.zking.mybatis..*.*Paging(..))")
    public  Object around(ProceedingJoinPoint point) throws Throwable {
        //获取所有参数,包括PageBane
        Object[] args = point.getArgs();
        PageBean pageBean=null;
        for (Object arg:args){
            if (arg instanceof  PageBean){//instanceof是否存在
                pageBean = (PageBean) arg;
                if(pageBean !=null && pageBean.isPagination()){
                    PageHelper.startPage(pageBean.getPage(),pageBean.getRows());//放入线程本地方法
                }
            }
        }
        //获取目标方法的分页参数,封装到List集合里
        Object rv = point.proceed();
        if(pageBean !=null && pageBean.isPagination()){
            PageInfo info=new PageInfo((List)rv);//获取List集合
            pageBean.setTotal((int) info.getTotal());
        }

        return  rv;
    }
}
@Around:环捞通知定义

mapper层

@Repository
public interface Iusermapper {   
/**
     * 分页
     * @param u 需要的实体
     * @return
     */
    List<User> queryPage(User u);
}
  <select id="queryPage" resultType="com.zking.mybatis.model.User">
     select id,name,loginName,pwd,rid from t_oa_user
     <where>
         <if test="name != null and name != ''">
             and name like concat('%', #{name}, '%')
         </if>
     </where>
    </select>

service层

 @Service
public class Userserviceimpl implements Iuserservice {

    @Autowired
    private Iusermapper iusermapper;

  /**
     * 分页
     * @param u
     * @param pagebean
     * @return
     */
    @Override
    public List<User> queryPagePaging(User u, PageBean pagebean) {
        /*if (pagebean != null && pagebean.isPagination()) {
            PageHelper.startPage(pagebean.getPage(), pagebean.getRows());
        }

        List<User> list = iusermapper.queryPage(u);

        if (pagebean != null && pagebean.isPagination()) {
            PageInfo info = new PageInfo(list);
            pagebean.setTotal((int) info.getTotal());
        }*/
        return iusermapper.queryPage(u);
    }
}
public interface Iuserservice { 
  /**
     * 分页
     * @param u
     * @param pagebean
     * @return
     */
    List<User> queryPagePaging(User u, PageBean pagebean);

}

Test测试 

//指定文件进行配置,用于生成spring上下文对象
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath*:applicationContext*.xml")
public class UserserviceimplTest {

    //通过mybatis与spring集成后进行依赖注入
    @Autowired
    private Iuserservice userserviceimpl;

    @Test
    public void queryPage(){
    User u=new User();
    PageBean pageBean = new PageBean();
    pageBean.setRows(4);
    List<User> list = userserviceimpl.queryPagePaging(u, pageBean);
    list.forEach(t-> System.out.println(t));
    }

}

5spring常用注解

  • @Controller:用于控制层的组件(spring的Action类似)
  • @Repository:用于数据访问层(DAO)的组件
  • @Service:用于业务逻辑层组件
  • @Component:泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
  • @Around:环捞通知定义
  • @Aspect:用于切面的组件

                
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatisSpring集成非常方便,可以通过Spring提供的MapperFactoryBean来创建映射器。MapperFactoryBean是一个FactoryBean,用于创建MyBatis的映射器。它可以自动创建映射器的实例,并使用Spring的注入机制自动将需要的依赖注入到映射器。 MapperFactoryBean的配置如下: ```xml <bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean"> <property name="mapperInterface" value="com.example.mybatis.UserMapper"/> <property name="sqlSessionFactory" ref="sqlSessionFactory"/> </bean> ``` 其,mapperInterface属性指定了映射器的接口类,sqlSessionFactory属性指定了MyBatis的SqlSessionFactory实例。 在映射器接口,可以使用MyBatis提供的注解来构建动态SQL语句。例如: ```java public interface UserMapper { @Select("SELECT * FROM user WHERE username = #{username}") User findByUsername(String username); @Insert("INSERT INTO user (username, password) VALUES (#{username}, #{password})") void insert(User user); @Update("UPDATE user SET password = #{password} WHERE id = #{id}") void updatePassword(User user); @Delete("DELETE FROM user WHERE id = #{id}") void deleteById(long id); @SelectProvider(type = UserSqlProvider.class, method = "findUsers") List<User> findUsers(String username, String email); class UserSqlProvider { public String findUsers(String username, String email) { StringBuilder sql = new StringBuilder("SELECT * FROM user WHERE 1 = 1"); if (username != null) { sql.append(" AND username = #{username}"); } if (email != null) { sql.append(" AND email = #{email}"); } return sql.toString(); } } } ``` 在这个例子,使用@Select、@Insert、@Update和@Delete注解来构建静态SQL语句。使用@SelectProvider注解来构建动态SQL语句。其,@SelectProvider注解指定了SQL语句构建类的类型和方法名。 在UserSqlProvider类,使用StringBuilder来构建SQL语句。通过判断参数是否为空,来决定是否拼接相应的SQL语句片段。最后,返回完整的SQL语句。 以上就是MyBatisSpring集成映射器及动态SQL的简单介绍。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值