一、什么是Mybatis

    可以简单将mybatis理解为ibatis的升级版本,它是一个java的持久层框架,底层依赖jdbc接口,此持久层框架包含sql maps与data access objects组件。mybatis可以通过xml或者注解的方式用于配置原始映射,将接口和java的pojo映射成数据库中的记录。

    下面是mybatis的层级关系,对于理解mybatis的源码有一定的帮助。

    

    1、API接口层:提供给外部使用的接口API,开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。
 
    2、数据处理层:负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调用的请求完成一次数据库操作。
 
    3、基础支撑层:负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是共用的东西,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的支撑。

  二、如何配置MyBatis

    开发环境:win10 64位英文版,sql2008r2,eclipse4.4,jdk1.7最新版本号,mavne3.2.1

    jar包版本:mybatis3.2.6,sqljdbc4-4.0,log4j-1.2.17、junit-4.11(可选)

    步骤:1、在eclipse中新建一个mavne project,选择maven-archetype-quickstart,选择下一步,在新窗口中的artifactid输入项目名称即可。

         2、在pom.xml中加入jar包依赖,如下:

<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<!-- 表示开发的时候引入,发布的时候不会加载此包 -->
<scope>test</scope>
</dependency> <!-- mybatis核心包 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.2.6</version>
</dependency> <!-- 导入SqlServer数据库链接jar包 -->
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>sqljdbc4</artifactId>
<version>4.0</version> </dependency> </dependencies>

      3、在项目里面src/main/java 这个source folder中新建一个mybatis的配置文件,如下:

<?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>
<!-- 注意:每个标签必须按顺序写,不然蛋疼的DTD会提示错误:The content of element type "configuration"
must match "(properties?,settings?,typeAliases?,typeHandlers?,objectFactory?,objectWrapperFactory?,plugins?,environments?,mappers?)". --> <!-- 数据库文件 -->
<properties resource="db.properties" /> <!-- environment 开发模式 work 工作模式 -->
<environments default="work">
<environment id="work">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="${driver}" />
<property name="url" value="${url}" />
<property name="username" value="${username}" />
<property name="password" value="${password}" />
</dataSource>
</environment>
</environments>
<!-- 注册映射文件 -->
<mappers>
<!-- 通过xml方式映射 -->
<mapper resource="com/mybatis/demo/userMapper.xml" />
<!-- 通过注解方式映射 -->>
<mapper class="com.mybatis.demo.IUserMapper" />
    </mappers>

</configuration>

      4、在第三步中注意到了<properties resource="db.properties" />这个,这样写是单独将数据库连接字符串放在一个db.properties文件中,如下:

driver = com.microsoft.sqlserver.jdbc.SQLServerDriver
url =jdbc:sqlserver://localhost:1433;databaseName=DBtest
username =sa
password = //这里的密码为空

    到这里,通过在pom.xml中添加jar包依赖、在代码文件夹中添加mybatis访问数据库的配置信息以及自身映射信息,新增一个db.properties存放数据库连接字符串信息,一个基本的mybatis测试项目就搭建起来了,如下图

    

  三、创建一个简单的select查询

    1、在sql2008中新建一个数据库dbtest,在里面新建一个表users,里面3个字段id,name,age

    2、新建一个users的pojo对象。 

package com.mybatis.demo;

public class User {

    private int id;
private String name;
private int age; public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
} public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
} @Override
public String toString() {
return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
} }

    3、通过xml方式映射数据

      在当前包下面新建一个userMapper.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.mybatis.demo.userMapper"> <!-- 根据ID查询得到一个user对象 --> <select id="getUser" parameterType="int" resultType="com.mybatis.demo.User"
resultMap="usermap">
select *
from Users where id_id=#{id}
</select> <resultMap type="com.mybatis.demo.User" id="usermap">
<!--id 针对主键 -->
<id property="id" column="id_id" />
<!-- result针对主键之外的字段 -->
<!-- 如果column写错了,返回值为类型默认值 <result property="name" column="name_s" /> -->
<result property="name" column="name_n" />
<result property="age" column="age_a" />
</resultMap> </mapper>

    4、通过注解方式映射数据

       在当前包下面新建一个IUserMapper接口

package com.mybatis.demo;

import org.apache.ibatis.annotations.Result;
import org.apache.ibatis.annotations.Results;
import org.apache.ibatis.annotations.Select; import com.mybatis.demo.*; public interface IUserMapper { @Select("select * from Users where id_id =#{id}")
@Results({ @Result(property="id", column="id_id"),
@Result(property="name" ,column="name_n"),
@Result(property="age" ,column="age_a") })
public User getById(int id);
}
 
  5、新建一个test类
package com.mybatis.demo;

import java.io.IOException;
import java.io.InputStream; import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class test {
public static void main(String[] args) throws IOException { //1、加载配置文件
String resource = "conf.xml";
InputStream inputStream = test.class.getClassLoader().getResourceAsStream(resource); //2、构建sqlSession的工厂
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(inputStream); //3、创建能执行映射文件中sql的sqlSession
SqlSession session = sessionFactory.openSession(); //4、映射sql的标识字符串
String statement = "com.mybatis.demo.userMapper.getUser"; //5、执行查询
User user1 = session.selectOne(statement, 56);
System.out.println("xml方式:"+user1); IUserMapper userMapper = session.getMapper(IUserMapper.class);
User user2 = userMapper.getById(56);
System.out.println("注解方式:"+user2); //6、关闭session对象
session.close();
}
}

  6、需要注意的几个地方

    6.1、需要在mybatis的配置文件中,上文中是conf.xml,在mappers节点中注册映射文件,可以以xml或者注解方式,如下

      <mapper resource="com/mybatis/demo/userMapper.xml" />  这里的resource是xml的文件路径

      <mapper class="com.mybatis.demo.IUserMapper" /> 这里的class是接口的全类名

      这两种方式任选其一即可。

    6.2、列别明映射,同样要么是xml方式要么是注解方式,如下

      <select id="" resultMap="usermap"></select>
      <resultMap type="" id="usermap"><id property="" column=""/><result/></resultMap>

      @Results({ @Result(property="", column="")}

      其中property表示pojo中的属性,column表示数据库表字段

   6.3、在通过xml方式执行sql语句的参数statement
     String statement = "com.mybatis.demo.userMapper.getUser";
     这里可以简单的理解为userMapper的全类名加上userMapper.xml文件中的节点ID,如图
        基本上主要注意上述3个问题,那么一个基于mybatis的简单CRUD操作可以顺利完成。
    
  

MyBatis之一:入门的更多相关文章

  1. MyBatis学习总结(一)——MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  2. MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  3. MyBatis学习总结(一)——MyBatis快速入门(转载)

    本文转载自http://www.cnblogs.com/jpf-java/p/6013537.html MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了 ...

  4. MyBatis入门学习教程-MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  5. MyBatis学习总结(一)——MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  6. 【转】MyBatis学习总结(一)——MyBatis快速入门

    [转]MyBatis学习总结(一)——MyBatis快速入门 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC ...

  7. mybatis快速入门(六)

    前面mybatis的入门程序基本上都写完了,就看大家的灵活运用了,今天来吧前面的整合一下封装一个公共的BaseDao 只需要把前面的改造下然后创建一个BaseDao的接口,其它的继承BaseDao接口 ...

  8. MyBatis学习总结-MyBatis快速入门的系列教程

    MyBatis学习总结-MyBatis快速入门的系列教程 [MyBatis]MyBatis 使用教程 [MyBatis]MyBatis XML配置 [MyBatis]MyBatis XML映射文件 [ ...

  9. MyBatis基础入门《二十》动态SQL(foreach)

    MyBatis基础入门<二十>动态SQL(foreach) 1. 迭代一个集合,通常用于in条件 2. 属性 > item > index > collection : ...

  10. MyBatis基础入门《十九》动态SQL(set,trim)

    MyBatis基础入门<十九>动态SQL(set,trim) 描述: 1. 问题 : 更新用户表数据时,若某个参数为null时,会导致更新错误 2. 分析: 正确结果: 若某个参数为nul ...

随机推荐

  1. 【转】【玩转cocos2d-x之二十三】多线程和同步03-图片异步加载

    原创作品,转载请标明:http://blog.csdn.net/jackystudio/article/details/15334159 cocos2d-x中和Android,Windows都 一样, ...

  2. POJ 1083 Moving Tables

    题意:一个建筑物里有400个房间,房间都在一层里,在一个走廊的两侧,如图,现在要搬n张桌子,告诉你每张桌子是从哪个屋搬到哪个屋,搬桌子的线路之间不可以有重叠,问最少搬几次. 解法:贪心.一开始觉得只要 ...

  3. 翻译【ElasticSearch Server】第一章:开始使用ElasticSearch集群(5)

    数据操作与REST API(Data manipulation with REST API) ElasticSearch REST API可用于各种任务.多亏了它,我们可以管理索引,更改实例参数,检查 ...

  4. 【转】OFBiz安全组

    安全组标识 描述 用户系统级别BIZADMIN 全部商业应用程序权限组,具有全部商业应用程序管理权限,不是技术人员权限. bizadmin FLEXADMIN 缓存管理组,具有全部颗粒的权限. fle ...

  5. Cadence关闭StartPage的方法

    Cadence 16.5开始,打开原理图工具 Orcad Capture 时,总是会弹出startpage 页面,关闭它的方法: 解决方法如下: (1) View---Toolbar----Comma ...

  6. javascript跑马灯抽奖

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. linux下配置双网卡及RAC规划——1

    使用背景: 操作系统:centos 虚拟机:virtualbox RAC系统中需要双网卡,一个为公共的网络环境,一个为私有的网络环境,从而需要搭建双网络. 在菜单FILE中选择preferences, ...

  8. 我的web前端修炼之路从此开始

    看过一篇文章,上面说过要想学习一门新技术,从什么时候开始都是不晚的.但对于一名大四的学生,只会一点简单的网页架构,只懂得HTML,CSS,JavaScript简单的一点皮毛,却怎么也说不过去.但也是这 ...

  9. Asmack离线消息时间获取

    DelayInformation info = (DelayInformation)message.getExtension("x","jabber:x:delay&qu ...

  10. work_6

    这次的作业是阅读C++11的新特性并提出问题,作为一个大部分代码都是用C++的基本语法并没有特别关注C++一代又一代新特性的学生来说,首先我阅读了一些关于新特性的文章.为了更快的理解,我首先选择了阅读 ...