JAVA應用程序單獨集成Mybatis使用Demo

參考博客:http://www.cnblogs.com/magialmoon/archive/2013/10/30/3397828.htmlhtml


總體結構

 

 

POM依賴

    <dependency>

<groupId>org.mybatis</groupId>

<artifactId>mybatis</artifactId>

<version>3.2.3</version>

</dependency>

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

<version>5.1.26</version>

</dependency>

 

 

 

數據準備

CREATE TABLE `t_migu_top_data` (java

  `music_id` int(11) DEFAULT NULL,mysql

  `music_name` varchar(100) DEFAULT NULL,sql

  `music_author` varchar(100) DEFAULT NULL,緩存

) ENGINE=InnoDB DEFAULT CHARSET=utf8;mybatis

 

配置文件

mybatis-config.xmlapp

<?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>    

    <settings>   

        <!-- changes from the defaults for testing -->   

        <setting name="cacheEnabled" value="false" />   

        <setting name="useGeneratedKeys" value="true" />   

        <setting name="defaultExecutorType" value="REUSE" />   

    </settings>  

    <typeAliases>    

        <typeAlias alias="TopData" type="com.cmcc.top.mysql.entity.TopData"></typeAlias>    

    </typeAliases>    

        

    <environments default="development">    

        <environment id="development">    

            <transactionManager type="JDBC"></transactionManager>    

            <dataSource type="POOLED">    

                <property name="driver" value="com.mysql.jdbc.Driver" />    

                <property name="url" value="jdbc:mysql://172.23.28.57:3306/top?useUnicode=true&amp;characterEncoding=UTF-8" />    

                <property name="username" value="root" />    

                <property name="password" value="*****" />    

            </dataSource>    

        </environment>    

    </environments>    

        

    <mappers>    

        <mapper resource="sqlMap/TopDataMapper.xml"/>    

    </mappers>    

    

</configuration>   

 

 

TopDataMapper.xml性能

<?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" >

<mapper namespace="com.cmcc.top.mysql.dao.TopDataDao">

<sql id="tablename">t_migu_top_data</sql>

<sql id="Base_Column_List">

music_id,

music_name,

music_author

</sql>

<resultMap id="BaseResultMap" type="com.cmcc.top.mysql.entity.TopData">

<result column="music_id" property="musicId" jdbcType="VARCHAR" />

<result column="music_name" property="musicName" jdbcType="VARCHAR" />

<result column="music_author" property="musicAuthor" jdbcType="VARCHAR" />

</resultMap>

 

<insert id="createTopData" useGeneratedKeys="true" keyProperty="id" parameterType="com.cmcc.top.mysql.entity.TopData" >

 insert into <include refid="tablename" />

(

        music_id,

        music_name,

        music_author

)

values

(

 #{musicId},

 #{musicName},

 #{musicAuthor}
)

</insert>

<insert id="createTopDataByBatch" parameterType="java.util.List" >

insert into <include refid="tablename" />

(

        music_id,

        music_name,

        music_author
)

values

<foreach collection="list" item="item" index="index" separator="," >

(

         #{item.musicId},

         #{item.musicName},

         #{item.musicAuthor}
)

</foreach>

</insert>

 

<select id="getTopDataList" parameterType="java.util.Map" resultMap="BaseResultMap" >

select  <include refid="Base_Column_List" />

from 

<include refid="tablename" />

<where>

<if test="musicId !=null " >

and music_id = #{musicId}

</if>

<if test="musicName != null">

and music_name like '%${musicName}%'

</if>

<if test="musicAuthor != null">

and music_author like '%${musicAuthor}%'

</if>

<if test="musicLanguage != null">

and music_language = #{musicLanguage}

</if>

<if test="musicStyle != null">

and music_style = #{musicStyle}

</if>

<if test="startDate != null">

and create_time >= '${startDate}'

</if>

<if test="endDate != null">

and '${endDate}' >= create_time

</if>

</where>

</select>

 

<update id="updateTopData" parameterType="com.cmcc.top.mysql.entity.TopData" >

 update  <include refid="tablename" />

<set>

            <if test="musicStatus != null">

                music_status = #{musicStatus},

            </if>

            <if test="customerFilePath != null">

                customer_file_path = #{customerFilePath},

            </if>

</set>

where  music_id = #{musicId}

</update>

</mapper>

 

實體對象

public class TopData {

    private String musicId;
    private String musicName;
    private String musicAuthor;
...
}

 

 

接口Dao

public interface TopDataDao {

 

    

    public void createTopData(TopData topData);

    

    public void createTopDataByBatch(List<TopData> topDataList);

    

    public void updateTopData(TopData topData);

    

    //public void updateTopDataByBatch(List<TopData> topDataList);

    

    public List<TopData> getTopDataList(Map<String, Object> queryMap);

    

}

 

 

manager

 

public class TopDataManager {

 

    private static SqlSession sqlSession;

    private static TopDataDao topDataDao;

    

    public static void initialConnection() {    

        try{    

            String resource = "mybatis-config.xml";    

            Reader reader = Resources.getResourceAsReader(resource);    

            SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(reader);    

            sqlSession = ssf.openSession();  

            topDataDao = sqlSession.getMapper(TopDataDao.class);

        } catch (Exception e) {    

            e.printStackTrace();    

        } 

    }    

    

    public static void destroyConnection() {

        sqlSession.close();

    }

    

    public static void createTopData(TopData topData) {

        topDataDao.createTopData(topData); 

        sqlSession.commit();

    }

    

    public static void createTopDataByBatch(List<TopData> topDataList) {

        topDataDao.createTopDataByBatch(topDataList);

        sqlSession.commit();

    }

    

    public static void updateTopData(TopData topData) {

        topDataDao.updateTopData(topData);

        sqlSession.commit();

    }

    

    public static List<TopData> getTopDataList(Map<String, Object> queryMap) {

        return topDataDao.getTopDataList(queryMap);

    }

 

}

 

 

測試

  main 方法訪問便可測試

注意事項

一、mybatis會用log4j記錄日誌,可是開啓debug模式貌似對性能影響很是厲害。ui

 

二、mybatis的查詢緩存對性能的影響很是大,啓用和不啓用差距很是大

 

 

 

注意:mapper文件中必定要加上cache這一行,不然不生效。

相關文章
相關標籤/搜索