(整理)MyBatis入門教程(一)

本文轉載:html

http://www.cnblogs.com/hellokitty1/p/5216025.html#3591383java

本人文筆不行,根據上面博客內容引導,本身整理了一些東西mysql

首先給你們推薦幾個網頁:web

http://blog.csdn.net/isea533/article/category/2092001    沒事看看 - MyBatis工具:www.mybatis.tksql

http://www.mybatis.org/mybatis-3/zh/getting-started.html  入門數據庫

http://www.mybatis.tk/apache

http://mbg.cndocs.tk/api

MyBatis 本是apache的一個開源項目iBatis, 2010年這個項目由apache software foundation 遷移到了google code,而且更名爲MyBatis 。2013年11月遷移到Github。session

1、理解什麼是MyBatis?

MyBatis 是支持普通 SQL 查詢,存儲過程和高級映射的優秀持久層框架。 MyBatis 消除了幾乎全部的 JDBC 代碼和參數的手工設置以及對結果集的檢索。 MyBatis 可使用簡單的XML 或註解用於配置和原始映射,將接口和 Java 的 POJO( Plain Old Java Objects,普通的Java 對象)映射成數據庫中的記錄.mybatis

  1)MyBATIS 目前提供了三種語言實現的版本,包括:Java、.NET以及Ruby。(我主要學習java,就講java的使用)
  2)它提供的持久層框架包括SQL Maps和Data Access Objects(DAO)。
  3)mybatis與hibernate的對比?

   mybatis提供一種「半自動化」的ORM實現。
   這裏的「半自動化」,是相對Hibernate等提供了全面的數據庫封裝機制的「全自動化」ORM實現而言,「全自動」ORM實現了POJO和數據庫表之間的映射,以及 SQL 的自動生成和執行。

    而mybatis的着力點,則在於POJO與SQL之間的映射關係。

2、簡單例子(快速入門)

1)首先創建項目java web

2)配置mybatis所需的jar包,pom.xml

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.35</version>
        </dependency>

        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.2.8</version>
        </dependency>

        <!-- logback start -->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.7.7</version>
        </dependency>
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-core</artifactId>
            <version>1.1.3</version>
        </dependency>
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-access</artifactId>
            <version>1.1.3</version>
        </dependency>
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
            <version>1.1.3</version>
        </dependency>
        <!-- logback end -->

 3)建立數據庫數據(mybatis),建立表(t_user)

CREATE TABLE `t_user` (
  `id` int(11) NOT NULL auto_increment,
  `username` varchar(20) default NULL,
  `password` varchar(20) default NULL,
  `account` double(10,2) default NULL,
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 

4)mysql驅動配置文件mysql.properties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/mybatis
jdbc.username=admin
jdbc.password=123456

5)添加mybatis配置文件mybatis.cfg.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>

  <!-- 引入外部配置文件 -->
  <properties resource="mysql.properties"></properties>
  
  <!-- 爲JAVA Bean起類別名 -->
   <typeAliases >
        <!-- 別名方式1,一個一個的配置 type中放置的是類的全路徑,alias中放置的是類別名
        <typeAliase type="com.cy.mybatis.beans.UserBean" alias="UserBean"/> -->
        <!-- 別名方式2,自動掃描,將JAVA類的類名做爲類的類別名 -->
        <package name="com.wenyin.mybatis.beans"/>
   </typeAliases>
   <!-- 配置mybatis運行環境 -->
     <environments default="cybatis">
        <environment id="cybatis">
            <!-- type="JDBC" 表明使用JDBC的提交和回滾來管理事務 -->
            <transactionManager type="JDBC" />
            
            <!-- mybatis提供了3種數據源類型,分別是:POOLED,UNPOOLED,JNDI -->
            <!-- POOLED 表示支持JDBC數據源鏈接池 -->
            <!-- UNPOOLED 表示不支持數據源鏈接池 -->
            <!-- JNDI 表示支持外部數據源鏈接池 -->
            <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>
        <!-- 告知映射文件方式1,一個一個的配置
        <mapper resource="com/cy/mybatis/mapper/UserMapper.xml"/>-->
        <!-- 告知映射文件方式2,自動掃描包內的Mapper接口與配置文件 -->
        <package name="com/wenyin/mybatis/mapper"/>
    </mappers>
     
</configuration>

6)建立對應的實體對象

7)建立方法接口UserMapper.java和定義操做t_user表的sql映射文件UserMapper.xml

提供簡單的增刪改查數據信息。

package com.wenyin.mybatis.mapper;
import java.util.List;
import com.wenyin.mybatis.beans.UserBean;
public interface UserMapper {
    /**
     * 新增用戶
     * @param user
     * @return
     * @throws Exception
     */
    public int insertUser(UserBean user) throws Exception;
    /**
     * 修改用戶
     * @param user
     * @param id
     * @return
     * @throws Exception
     */
    public int updateUser (UserBean user,int id) throws Exception;
     /**
      * 刪除用戶
      * @param id
      * @return
      * @throws Exception
      */
    public int deleteUser(int id) throws Exception;
    /**
     * 根據id查詢用戶信息
     * @param id
     * @return
     * @throws Exception
     */
    public UserBean selectUserById(int id) throws Exception;
     /**
      * 查詢全部的用戶信息
      * @return
      * @throws Exception
      */
    public List<UserBean> selectAllUser() throws Exception;
}

UserMapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!-- 不寫會報錯 -->
<!DOCTYPE mapper PUBLIC "-//mybatis.org/DTD Mapper 3.0" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.wenyin.mybatis.mapper.UserMapper">
<!-- 自定義返回結果集 -->
   <resultMap id="userMap" type="UserBean">
        <id property="id" column="id" javaType="java.lang.Integer"></id>
        <result property="username" column="username" javaType="java.lang.String"></result>
        <result property="password" column="password" javaType="java.lang.String"></result>
        <result property="account" column="account" javaType="java.lang.Double"></result>
    </resultMap>
<!-- 在各類標籤中的id屬性必須和接口中的方法名相同 , id屬性值必須是惟一的,不可以重複使用。parameterType屬性指明查詢時使用的參數類型,
resultType屬性指明查詢返回的結果集類型-->    
<!-- useGeneratedKeys:( 僅 對 insert 有 用 ) 這 會 告 訴 MyBatis 使 用 JDBC 的getGeneratedKeys 
     方法來取出由數據(好比:像 MySQL 和 SQLServer 這樣的數據庫管理系統的自動遞增字段)內部生成的主鍵。默認值: false。 
oracle 不支持應該設置成 useGeneratedKeys="false" 否則會報錯
--> <!--keyProperty: (僅對 insert有用)標記一個屬性, MyBatis 會經過 getGeneratedKeys或者經過 insert 語句的 selectKey 子元素設置它的值。默認:不設置。 --> <!--#{}中的內容,爲佔位符,當參數爲某個JavaBean時,表示放置該Bean對象的屬性值 --> <insert id="insertUser" useGeneratedKeys="true" keyProperty="id"> insert into t_user (username,password,account) values (#{username},#{password},#{account}) </insert> <update id="updateUser" > update t_user set username=#{username},password=#{password},account=#{account} where id=#{id} </update> <delete id="deleteUser" parameterType="int"> delete from t_user where id=#{id} </delete> <select id="selectUserById" parameterType="int" resultMap="userMap"> select * from t_user where id=#{id} </select> <select id="selectAllUser" resultMap="userMap"> select * from t_user </select> </mapper>

這時須要爲mybatis.cfg.xml裏註冊UserMapper.xml文件。

參照第5)步驟

8)須要創建一個工具類文件

package com.wenyin.mybatis.tools;

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

public class DBTools {
    public static SqlSessionFactory sessionFactory;
    
    static{
        try {
            //使用MyBatis提供的Resources類加載mybatis的配置文件
            Reader reader = Resources.getResourceAsReader("mybatis.cfg.xml");
            //構建sqlSession的工廠
            sessionFactory = new SqlSessionFactoryBuilder().build(reader);
        } catch (Exception e) {
            e.printStackTrace();
        }
        
    }
    //建立能執行映射文件中sql的sqlSession
    public static SqlSession getSession(){
        return sessionFactory.openSession();
    }
    
}

9)寫個測試UserService.java

package com.wenyin.mybatis.service;

import java.util.List;
import org.apache.ibatis.session.SqlSession;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.wenyin.mybatis.beans.UserBean;
import com.wenyin.mybatis.mapper.UserMapper;
import com.wenyin.mybatis.tools.DBTools;

public class UserService {

    private static Logger logger = LoggerFactory.getLogger(UserService.class); 
    public static void main(String[] args) {
        insertUser();
        //deleteUser(1);
        //selectUserById(2);
        //selectAllUser();
    }

    
    /**
     * 新增用戶
     */
    private static boolean  insertUser(){
        SqlSession session = DBTools.getSession();
        UserMapper mapper = session.getMapper(UserMapper.class);
        UserBean user = new UserBean("test01", "123456", 7000.0);
        try {
            int index=mapper.insertUser(user);
            boolean bool=index>0?true:false;
            logger.error("新增用戶user對象:{},操做狀態:{}",new Object[]{user,bool});
             session.commit();
             return bool;
        } catch (Exception e) {
            e.printStackTrace();
            session.rollback();
            return false;
        }finally{
            session.close();
        } }
/** * 刪除用戶 * @param id 用戶ID */ private static boolean deleteUser(int id){ SqlSession session=DBTools.getSession(); UserMapper mapper=session.getMapper(UserMapper.class); try { int index=mapper.deleteUser(id); boolean bool=index>0?true:false; logger.debug("根據用戶id:{},操做狀態{}",new Object[]{id,bool}); session.commit(); return bool; } catch (Exception e) { e.printStackTrace(); session.rollback(); return false; }finally{
            session.close();
        } }
/** * 根據id查詢用戶 * @param id */ private static void selectUserById(int id){ SqlSession session=DBTools.getSession(); UserMapper mapper=session.getMapper(UserMapper.class); try { UserBean user= mapper.selectUserById(id); logger.debug("根據用戶Id:{},查詢用戶信息:{}",new Object[]{id,user}); session.commit(); } catch (Exception e) { e.printStackTrace(); session.rollback(); }finally{
            session.close();
        } }
/** * 查詢全部的用戶 */ private static void selectAllUser(){ SqlSession session=DBTools.getSession(); UserMapper mapper=session.getMapper(UserMapper.class); try { List<UserBean> user=mapper.selectAllUser(); logger.debug("獲取所用的用戶:{}",user); session.commit(); } catch (Exception e) { e.printStackTrace(); session.rollback(); }finally{
            session.close();
        } } }

新增運行結果:

 

 

若是返回Map<String,Object>
    <select id="getMap" resultType="java.util.HashMap" parameterType="int">
        select username,id from
        t_user where
        id=#{id}
    </select>

  返回List<Map<String,Object>>      <select id="getList" resultType="java.util.HashMap" >         SELECT * FROM t_user    </select>

相關文章
相關標籤/搜索