Idea中maven環境下搭建MyBatis項目(一)


1、選擇Maven框架下的webapp

1.1 添加新節點:archetypeCatalog=internal

1.2 或者在settings------->Build,Execution,Deployment——>Maven——>VM Options設置 -DarchetypeCatalog=internal

 

2、在Maven的pom文件中引入MyBatis需要用的jar包:

創建對應的java項目,引入需要的mybatis需要的jar,以及連接mysql數據庫的jar!

asm-3.3.1.jar:操作Javaj字節碼的類庫

cglib-2.2.2.jar:用來動態集成Java類或實現接口

commons-logging-1.1.1.jar:用於通用日志處理

javassist-3.17.1-GA.jar:分析、編輯和創建Java字節碼的類庫

log4j-1.2.17.jar:日志系統

slf4j-api-1.7.5.jar:日志系統的封裝,對外提供統一的API接口

slf4j-log4j12-1.7.5.jar:slf4j對log4j的對應驅動,完成slf4j綁定log4j

mybatis-3.2.2.jar

mysql-connector-java-5.1.7-bin.jar/3

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <parent>
        <artifactId>Book_08</artifactId>
        <groupId>cn.alexander</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>
    <artifactId>MyBatis</artifactId>
    <packaging>war</packaging>
    <name>MyBatis Maven Webapp</name>
    <url>http://maven.apache.org</url>
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.3</version>
            <scope>test</scope>
        </dependency>


        <!--配置mybatis需要的依賴包-->
        <dependency>
            <groupId>asm</groupId>
            <artifactId>asm</artifactId>
            <version>3.3.1</version>
        </dependency>

        <dependency>
            <groupId>cglib</groupId>
            <artifactId>cglib</artifactId>
            <version>2.2.2</version>
        </dependency>

        <dependency>
            <groupId>commons-logging</groupId>
            <artifactId>commons-logging</artifactId>
            <version>1.1.1</version>
        </dependency>
        <dependency>
            <groupId>org.javassist</groupId>
            <artifactId>javassist</artifactId>
            <version>3.17.1-GA</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.6</version>
        </dependency>
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.7</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.7.5</version>
        </dependency>

        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.5</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.3.0</version>
        </dependency>






    </dependencies>
    <build>
       <resources>
           <resource>
               <directory>src/main/java</directory>
               <includes>
                   <include>**/*.xml</include>
               </includes>
           </resource>
       </resources>
    </build>
</project>

 

3、創建MyBatis核心配置文件mybatis-config.xml

MyBatis核心配置文件主要用於配置數據庫連接和MyBatis運行時所需的各種特性,包含了設置和影響MyBatis行為的屬性。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTDConfig 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <properties resource="jdbc.properties"></properties>
    <settings>
        <setting name="lazyLoadingEnabled" value="true"/>
        <setting name="aggressiveLazyLoading" value="true"></setting>
    </settings>
   <!-- <settings>
        <setting name="autoMappingBehavior" value="NONE"/>
    </settings>-->
    <typeAliases>
    <package name="cn.alexander.entity"></package>
    </typeAliases>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
      <!--  <mapper resource="cn/alexander/dao/IStudentDAO.xml"/>-->
        <package name="cn.alexander.dao"></package>
    </mappers>
</configuration>

4、創建數據庫表

 

 5、在idea中創建實體類

package cn.alexander.entity;

import java.io.Serializable;


public class Dept implements Serializable {
    private Integer deptno;
    private String deptname;

    public Integer getDeptno() {
        return deptno;
    }

    public void setDeptno(Integer deptno) {
        this.deptno = deptno;
    }

    public String getDeptname() {
        return deptname;
    }

    public void setDeptname(String deptname) {
        this.deptname = deptname;
    }

    public Dept(Integer deptno, String deptname) {
        this.deptno = deptno;
        this.deptname = deptname;
    }

    public Dept(String deptname) {
        this.deptname = deptname;
    }

    public Dept() {
    }

    @Override
    public String toString() {
        return "Dept{" +
                "deptno=" + deptno +
                ", deptname='" + deptname + '\'' +
                '}';
    }
}

6、創建接口

package cn.alexander.dao;

import cn.alexander.entity.Dept;

import java.util.List;

public interface IDeptDAO {
    // 查詢所有的部門
    public List<Dept> findAll();
}

7、創建接口的實現類

7.1使用單例創建seession

package cn.alexander.util;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.InputStream;

/**
 * SqlSessionFactory的單例類
 */
public class SessionFactoryUtil {
    // 創建需要單例的對象實例
    private static SqlSessionFactory sessionFactory;

    // 私有化構造
    private SessionFactoryUtil(){}

    // 對外提供訪問接口
    public static synchronized SqlSession getSession(){
        try {
            InputStream stream = Resources.getResourceAsStream("mybatis-config.xml");
            // 判斷SqlSessionFactory是否為空,如果為空則創建
            if(sessionFactory==null){
                sessionFactory = new SqlSessionFactoryBuilder().build(stream);
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
        return sessionFactory.openSession();
    }


}

7.2通過session實現方法

package cn.alexander.dao;

import cn.alexander.entity.Dept;
import cn.alexander.util.SessionFactoryUtil;
import org.apache.ibatis.session.SqlSession;

import java.util.List;

public class IDeptDAOImpl implements IDeptDAO {
    public List<Dept> findAll() {
        // 獲取session
        SqlSession session = null;
        List<Dept> depts = null;
        try{
            session = SessionFactoryUtil.getSession();
            IDeptDAO mapper = session.getMapper(IDeptDAO.class);
            depts = mapper.findAll();
        }catch (Exception e){
            e.printStackTrace();
        }finally {
            session.close();
        }
        return depts;
    }
}

8、接口對應的配置文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--映射文件的根節點
  namespace
-->
<mapper namespace="cn.alexander.dao.IDeptDAO">
    <select id="findAll" resultType="Dept">
        select * from dept
    </select>
</mapper>

修改pom.xml中的build節點。保證即使不在resources文件夾下的配置文件也能被讀取

 <build>
       <resources>
           <resource>
               <directory>src/main/java</directory>
               <includes>
                   <include>**/*.xml</include>
               </includes>
           </resource>
       </resources>
    </build>

 

9、主配置關聯小配置

 在mybatis-config.xml中用mappers節點使主配置關聯到小配置

 <mappers>
      <!--  <mapper resource="cn/alexander/dao/IStudentDAO.xml"/>-->
        <package name="cn.alexander.dao"></package>
    </mappers>

10、編寫測試類

package cn.alexander.test;

import cn.alexander.dao.IDeptDAO;
import cn.alexander.dao.IDeptDAOImpl;
import cn.alexander.entity.Dept;
import org.apache.log4j.Logger;
import org.junit.Test;

import java.util.List;

public class Test20170923 {
    Logger logger = Logger.getLogger(Test20170923.class);
    @Test
    public void findAll(){
        IDeptDAO iDeptDAO = new IDeptDAOImpl();
        List<Dept> depts = iDeptDAO.findAll();
        logger.debug(depts);
    }
}

11、測試類運行結果:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM