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 也可以实现映射(输入映射、输出映射)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值