zoukankan      html  css  js  c++  java
  • 《Java Spring框架》通过Idea 整合Spring和Mybatis

    1. Jar包下载

    百度云下载:链接: https://pan.baidu.com/s/1sVUovsBfj8NWdthGIbyqGA 提取码: 8v3u 复制这段内容后打开百度网盘手机App,操作更方便哦

    2 通过IDEA整合

    第一步:新增项目

    第二步:不通过Gradle也可以的,选好java 和 web 点击下一步。

    第三步:取个名字

    第四步:设置Gradle 和 JDK版本,当然没有gradle也不影响的。

    第五步:新增lib文件,用于存放下载的jar包,也可以通过Gradle下载。

    第六步:build.gradle文件 ,引入jar包。

    group 'ssm'
    version '1.0-SNAPSHOT'
    
    apply plugin: 'java'
    apply plugin: 'war'
    
    sourceCompatibility = 1.8
    
    repositories {
        mavenCentral()
    }
    
    dependencies {
        testCompile group: 'junit', name: 'junit', version: '4.12'
        compile files('lib/c3p0-0.9.5.2.jar')
        compile files('lib/com.springsource.org.aopalliance-1.0.0.jar')
        compile files('lib/com.springsource.org.apache.commons.logging-1.1.1.jar')
        compile files('lib/com.springsource.org.aspectj.weaver-1.6.8.RELEASE.jar')
        compile files('lib/mchange-commons-java-0.2.11.jar')
        compile files('lib/mysql-connector-java-5.1.46-bin.jar')
        compile files('lib/ojdbc7.jar')
        compile files('lib/spring-aop-5.0.8.RELEASE.jar')
        compile files('lib/spring-aspects-5.0.8.RELEASE.jar')
        compile files('lib/spring-beans-5.0.8.RELEASE.jar')
        compile files('lib/spring-context-5.0.8.RELEASE.jar')
        compile files('lib/spring-core-5.0.8.RELEASE.jar')
        compile files('lib/spring-expression-5.0.8.RELEASE.jar')
        compile files('lib/spring-jdbc-5.0.8.RELEASE.jar')
        compile files('lib/spring-tx-5.0.8.RELEASE.jar')
        compile files('lib/mybatis-3.4.6.jar')
        compile files('lib/mybatis-spring-1.3.2.jar')
        compile group: 'org.springframework', name: 'spring-test', version: '5.0.8.RELEASE'
    }

    跑了测试案例:

    数据库表数据如下:

    目录结构:

    /**
     * 账户
     * @author hubt
     */
    public class Account {
        private Integer id;
        private String name;
        private Double money;
        
        //转账金额
        private Double tranferMoney;
        public Double getTranferMoney() {
            return tranferMoney;
        }
        public void setTranferMoney(Double tranferMoney) {
            this.tranferMoney = tranferMoney;
        }
        public Integer getId() {
            return id;
        }
        public void setId(Integer id) {
            this.id = id;
        }
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
        public Double getMoney() {
            return money;
        }
        public void setMoney(Double money) {
            this.money = money;
        }
    }
    import com.tao.bean.Account;
    
    /**
     * 账户mapper接口
     * @author Joey
     *
     */
    public interface AccountMapper {
        //操作数据库扣款和加款
        
        //扣款
        void subMoney(Account pay);
        
        
        //加款
        void addMoney(Account collect);
    }
    /**
     * 账户接口
     * @author hubt
     *
     */
    public interface AccountService {
        
        //转账方法
        void updateTranferAccount();
    }
    import javax.annotation.Resource;
    
    import com.tao.bean.Account;
    import com.tao.mapper.AccountMapper;
    import org.springframework.transaction.annotation.Isolation;
    import org.springframework.transaction.annotation.Propagation;
    import org.springframework.transaction.annotation.Transactional;
    
    @Transactional(isolation= Isolation.DEFAULT, propagation= Propagation.REQUIRED, readOnly=false)
    public class AccountServiceImpl implements AccountService {
        
        @Resource(name = "accountMapper")
        private AccountMapper mapper;
    
        @Override
        public void updateTranferAccount() {
            Double tranferMoney = 1000d;
            Account pay = new Account();
            pay.setId(1);
            pay.setTranferMoney(tranferMoney);
            //先扣款
            mapper.subMoney(pay);
            Account collect = new Account();
            collect.setId(2);
            collect.setTranferMoney(tranferMoney);
            //加款
            mapper.addMoney(collect);
        }
    }
    import javax.annotation.Resource;
    
    import org.junit.Test;
    import org.junit.runner.RunWith;
    import org.springframework.test.context.ContextConfiguration;
    import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
    
    import com.tao.service.AccountService;
    
    @RunWith(SpringJUnit4ClassRunner.class)
    @ContextConfiguration("classpath:applicationContext.xml")
    public class MapperTest {
    
        @Resource(name="accountService")
        private AccountService as;
    
        @Test
        public void Test1() {
            as.updateTranferAccount();
        }
    }

    配置文件: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: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-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/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
            http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.3.xsd">
            
        <!-- 读取配置文件 -->
        <context:property-placeholder location="db.properties"/>
        
        <!-- 配置 dataSource -->
        <bean name="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
            <property name="driverClass" value="${jdbc.driverClass}"/>
            <property name="jdbcUrl" value="${jdbc.jdbcUrl}"/>
            <property name="user" value="${jdbc.user}"/>
            <property name="password" value="${jdbc.password}"/>
        </bean>
        
        <!-- mybatis -->
        <bean name="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
            <property name="dataSource" ref="dataSource"/>
            <property name="configLocation" value="classpath:sqlMapConfig.xml"/>
        </bean>
        
        <!-- mapper工厂 -->
        <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <property name="basePackage" value="com.tao.mapper"/>
        </bean>
        
        <!-- service -->
        <bean name="accountService" class="com.tao.service.AccountServiceImpl"></bean>
    
        <!-- 需要事务核心管理器 -->
        <bean name="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
            <property name="dataSource" ref="dataSource"/>
        </bean>
    
        <!-- 开启注解事务 -->
        <tx:annotation-driven/>
        
    </beans>

    配置文件:db.properties

    jdbc.driverClass=com.mysql.jdbc.Driver
    jdbc.jdbcUrl=jdbc:mysql://localhost:3306/work_db
    jdbc.user=root
    jdbc.password=******

    sqlMapConfig.xml

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration
      PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
      "http://mybatis.org/dtd/mybatis-3-config.dtd">
      
      <configuration>
          <typeAliases>
              <package name="com.tao.bean"/>
          </typeAliases>
      </configuration>

    运行结果:

    总结:就这样的完美。

    This moment will nap, you will have a dream; But this moment study,you will interpret a dream.
  • 相关阅读:
    sys模块
    os模块
    datetime模块
    time模块

    random模块
    python文件两种用途
    模块的搜索路径
    如何修改cnblogs的文本编辑器
    socket状态
  • 原文地址:https://www.cnblogs.com/jssj/p/12149540.html
Copyright © 2011-2022 走看看