MyBatis入門

MyBatis
MyBatis 本是apache的一個開源項目iBatis, 2010年這個項目由apache software foundation 遷移到了google code,並且改名爲MyBatis 。2013年11月遷移到Github。iBATIS一詞來源於“internet”和“abatis”的組合,是一個基於Java的持久層框架。iBATIS提供的持久層框架包括SQL Maps和Data Access Objects(DAO)。

開發工具:idea
語言:java
項目結構:maven項目
mysql數據庫

1、入門案例

1.1、db.properties文件

jdbc.url=jdbc:mysql://localhost:3306/mybatis?characterEncoding=UTF-8  
jdbc.username=用戶名  
jdbc.password=密碼

1.1.1SQL語句、數據表

/* 
SQLyog v10.2  
MySQL - 5.1.72-community : Database - mybatis 
********************************************************************* 
*/  
/*Table structure for table `items` */  

CREATE TABLE `items` (  
  `id` int(11) NOT NULL AUTO_INCREMENT,  
  `name` varchar(32) NOT NULL COMMENT '商品名稱',  
  `price` float(10,1) NOT NULL COMMENT '商品定價',  
  `detail` text COMMENT '商品描述',  
  `pic` varchar(64) DEFAULT NULL COMMENT '商品圖片',  
  `createtime` datetime NOT NULL COMMENT '生產日期',  
  PRIMARY KEY (`id`)  
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;  

/*Table structure for table `orderdetail` */  

CREATE TABLE `orderdetail` (  
  `id` int(11) NOT NULL AUTO_INCREMENT,  
  `orders_id` int(11) NOT NULL COMMENT '訂單id',  
  `items_id` int(11) NOT NULL COMMENT '商品id',  
  `items_num` int(11) DEFAULT NULL COMMENT '商品購買數量',  
  PRIMARY KEY (`id`),  
  KEY `FK_orderdetail_1` (`orders_id`),  
  KEY `FK_orderdetail_2` (`items_id`),  
  CONSTRAINT `FK_orderdetail_1` FOREIGN KEY (`orders_id`) REFERENCES `orders` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION,  
  CONSTRAINT `FK_orderdetail_2` FOREIGN KEY (`items_id`) REFERENCES `items` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION  
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;  

/*Table structure for table `orders` */  

CREATE TABLE `orders` (  
  `id` int(11) NOT NULL AUTO_INCREMENT,  
  `user_id` int(11) NOT NULL COMMENT '下單用戶id',  
  `number` varchar(32) NOT NULL COMMENT '訂單號',  
  `createtime` datetime NOT NULL COMMENT '創建訂單時間',  
  `note` varchar(100) DEFAULT NULL COMMENT '備註',  
  PRIMARY KEY (`id`),  
  KEY `FK_orders_1` (`user_id`),  
  CONSTRAINT `FK_orders_id` FOREIGN KEY (`user_id`) REFERENCES `user` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION  
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;  

/*Table structure for table `user` */  

CREATE TABLE `user` (  
  `id` int(11) NOT NULL AUTO_INCREMENT,  
  `username` varchar(32) NOT NULL COMMENT '用戶名稱',  
  `birthday` date DEFAULT NULL COMMENT '生日',  
  `sex` char(1) DEFAULT NULL COMMENT '性別',  
  `address` varchar(256) DEFAULT NULL COMMENT '地址',  
  PRIMARY KEY (`id`)  
) ENGINE=InnoDB AUTO_INCREMENT=27 DEFAULT CHARSET=utf8;  

插入數據:

/* 
SQLyog v10.2  
MySQL - 5.1.72-community : Database - mybatis 
********************************************************************* 
*/  
/*Data for the table `items` */  

insert  into `items`(`id`,`name`,`price`,`detail`,`pic`,`createtime`) values (1,'臺式機',3000.0,'該電腦質量非常好!!!!',NULL,'2016-02-03 13:22:53'),(2,'筆記本',6000.0,'筆記本性能好,質量好!!!!!',NULL,'2015-02-09 13:22:57'),(3,'揹包',200.0,'名牌揹包,容量大質量好!!!!',NULL,'2016-02-06 13:23:02');  

/*Data for the table `orderdetail` */  

insert  into `orderdetail`(`id`,`orders_id`,`items_id`,`items_num`) values (1,3,1,1),(2,3,2,3),(3,4,3,4),(4,4,2,3);  

/*Data for the table `orders` */  

insert  into `orders`(`id`,`user_id`,`number`,`createtime`,`note`) values (3,1,'1000010','2016-02-04 13:22:35',NULL),(4,1,'1000011','2016-02-03 13:22:41',NULL),(5,10,'1000012','2016-02-12 16:13:23',NULL);  

/*Data for the table `user` */  

insert  into `user`(`id`,`username`,`birthday`,`sex`,`address`) values (1,'王五',NULL,'2',NULL),(10,'張三','2016-07-10','1','北京市'),(16,'張小明',NULL,'1','河南鄭州'),(22,'陳小明',NULL,'1','河南鄭州'),(24,'張三丰',NULL,'1','河南鄭州'),(25,'陳小明',NULL,'1','河南鄭州'),(26,'王五',NULL,NULL,NULL);  

1.2、pom.xml文件

<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/xsd/maven-4.0.0.xsd">  
    <modelVersion>4.0.0</modelVersion>  
    <groupId>web-test-com</groupId>  
    <artifactId>MyBatis</artifactId>  
    <version>0.0.1-SNAPSHOT</version>  
    <packaging>war</packaging>  

    <dependencies>  


        <dependency>  
            <groupId>junit</groupId>  
            <artifactId>junit</artifactId>  
            <version>4.12</version>  
            <scope>provided</scope>  
        </dependency>  

        <dependency>  
            <groupId>log4j</groupId>  
            <artifactId>log4j</artifactId>  
            <version>1.2.17</version>  
        </dependency>  

        <dependency>  
            <groupId>org.mybatis</groupId>  
            <artifactId>mybatis</artifactId>  
            <version>3.1.1</version>  
        </dependency>  
        <dependency>  
            <groupId>mysql</groupId>  
            <artifactId>mysql-connector-java</artifactId>  
            <version>5.1.38</version>  
        </dependency>  

    </dependencies>  


</project>  

1.3、SqlMappingConfig.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="db.properties">  
        <!--properties中還可以配置一些屬性名和屬性值 -->  
        <!-- <property name="jdbc.driver" value=""/> -->  
    </properties>  

    <!-- 全局配置參數,需要時再設置 -->  
    <!-- <settings> </settings> -->  

    <typeAliases>  
        <!-- 別名定義 -->  
        <!-- 針對單個別名定義 type:類型的路徑 alias:別名 -->  
        <!-- <typeAlias type="cn.czy.mybatis.po.User" alias="user"/> -->  
        <typeAlias type="cn.com.czy.mybatis.pojo.User" alias="user" />  
        <!-- 批量別名定義 指定包名,mybatis自動掃描包中的po類,自動定義別名,別名就是類名(首字母大寫或小寫都可以) -->  
        <package name="cn.com.mybatis.mapper" />  
    </typeAliases>  

    <!-- 和spring整合後 environments配置將廢除 -->  
    <environments default="development">  
        <environment id="development">  
            <!-- 使用jdbc事務管理,事務控制由mybatis -->  
            <transactionManager type="JDBC" />  
            <!-- 數據庫連接池,由mybatis管理 -->  
            <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>  


        <!--通過resource方法一次加載一個映射文件 -->  
                <!--注意這裏的路徑和xml文件 -->  
               <mapper resource="sqlMapper/user.xml" />  
        <mapper resource="sqlMapper/userMapper.xml" />  
        <mapper resource="sqlMapper/OrdersMapperCustom.xml"/>  

        <!-- 批量加載mapper 指定mapper接口的包名,mybatis自動掃描包下邊所有mapper接口進行加載 -->  
        <!-- 遵循一些規範:需要將mapper接口類名和mapper.xml映射文件名稱保持一致,且在一個目錄 -->  
        <!-- 中 上邊規範的前提是:使用的是mapper代理方法   
        <package name="cn.com.czy.mybatis.two.mapper" />-->  

    </mappers>  

</configuration>  

1.4、user.xml文件(注意在SqlMappingConfig.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="test">  

    <!-- 在 映射文件中配置很多sql語句 -->  
    <!-- 將sql語句封裝到mappedStatement對象中,所以將id稱爲statement的id -->  
    <!-- parameterType:指定輸入 參數的類型,這裏指定int型 #{}表示一個佔位符號 -->  
    <!-- #{id}:其中的id表示接收輸入 的參數,參數名稱就是id,如果輸入 -->  
    <!-- 參數是簡單類型,#{}中的參數名可以任意,可以value或其它名稱 -->  
    <!-- resultType:指定sql輸出結果 的所映射的java對象類型,select指定resultType表示將單條記錄映射成的java對象。 -->  
    <select id="findUserById" parameterType="int"  resultType="user">  
        SELECT * FROM USER WHERE id=#{value}  
    </select>  
</mapper>  

1.5、測試類

import java.io.IOException;  
import java.io.InputStream;  
import java.util.Date;  
import java.util.List;  

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 cn.com.czy.mybatis.pojo.User;  
import org.junit.Test;  

/** 
 * 《單表映射》 
 * 入門程序總結:這是簡單的mybatis入門程序 
 * -- 1、映射(mapper)文件是user.xml --  --  
 * -- 2、邏輯基本的resultType、parameterType等一下基礎知識  --  --  
 * -- 3、SqlSessionFactory、SqlSession的原理  --  --  
 */  
public class MybatisFirst {  

    public SqlSessionFactory getSqlSessionFactory() throws IOException {  
        // mybatis配置文件  
        String resource = "config/SqlMapConfig.xml";  
        // 得到配置文件流  
        InputStream inputStream = Resources.getResourceAsStream(resource);  
        // 創建會話工廠,傳入mybatis的配置文件信息  
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);  
        return sqlSessionFactory;  
    }  

    // 根據id查詢用戶信息,得到一條記錄結果  
    @Test  
    public void findUserByIdTest() throws IOException {  

        // 通過工廠得到SqlSession  
        SqlSession sqlSession = this.getSqlSessionFactory().openSession();  

        // 通過SqlSession操作數據庫  
        // 第一個參數:映射文件中statement的id,等於=namespace+"."+statement的id  
        // 第二個參數:指定和映射文件中所匹配的parameterType類型的參數  
        // sqlSession.selectOne結果 是與映射文件中所匹配的resultType類型的對象  

                // selectOne查詢出一條記錄(這種很麻煩的!!!往後看看)  
        User user = sqlSession.selectOne("test.findUserById", 1);  
        System.out.println(user);  
        // 釋放資源  
        sqlSession.close();  
    }  
}  

1.6、selectOne和selectList的解釋
- selectOne表示查詢出一條記錄進行映射。如果使用selectOne可以實現使用selectList也可以實現(list中只有一個對象)。
- selectList表示查詢出一個列表(多條記錄)進行映射。如果使用selectList查詢多條記錄,不能使用selectOne。

總結:mybatis和hibernate本質區別和應用場景?
hibernate:是一個標準ORM框架(對象關係映射)。入門門檻較高的,不需要程序寫sql,sql語句自動生成了。
對sql語句進行優化、修改比較困難的。
mybatis:專注是sql本身,需要程序員自己編寫sql語句,sql修改、優化比較方便。mybatis是一個不完全的ORM框架,雖然程序員自己寫sql,mybatis 也可以實現映射(輸入映射、輸出映射)。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章