作为ORM的重要框架,MyBatis是iBatis的升级版。Mybatis完全将SQL语句交给编程人员掌控,这点和Hibernate的设计理念不同(至于Hibernate的理念,待我先学习学习)。

下面的教程,是一个基于STS(也可以是eclipse,需要事先安装好maven)的一个入门级教程。下文分为两个部分,第一部门为简单版教程,第二部分是step-by-step教程。

Part one

简单教程:

  1. 新建maven工程。
  2. 添加mybatis和mysql包,以及log4j的包。
  3. 新建或者使用现存的数据库,并准备好若干语句。例如使用mysql的默认数据库world。
  4. 新建mybatis-config.xml配置文件,作为mybaits的基础配置。
  5. 新建POJO,City。
  6. 新建mapper文件:city.xml,进行配置。
  7. 新建Interface,CityMapper,对应city.xml的方法。
  8. 新建Class: CityService,并implemente CityMapper,实现各种方法。
  9. 新建Class:MyBatisSqlSessionFactory,用户获取mybatis的session
  10. 新建测试文件,进行测试。

--完--

Part two

这部分对第一部分进行细化,并配以图片说明:

详细教程:

  1. 新建maven工程。
    • 选择新建工程,选择maven项目
    • 选择quickStart类型的maven:
    • 输入Group Id和Artifact Id并完成工程:
  2. 添加mybatis和mysql包,以及log4j的包。
    • 编辑pom.xml文件,添加以下包:

      其中红框内的为必选,其余随意。

    其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>jacob</groupId>
<artifactId>mybatisdemo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging> <name>mybatisdemo</name>
<url>http://maven.apache.org</url> <properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties> <dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<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.27</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.5</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.5</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
<scope>runtime</scope>
</dependency>
</dependencies>
</project>

      

    •   整个工程的目录如下:

  1.   新建或者使用现存的数据库,并准备好若干语句。例如使用mysql的默认数据库world。
    这是个现成的数据库(懒得新建一个),本教程只用到其中的一张表,表结构如下:

  2. 新建mybatis-config.xml配置文件,作为mybaits的基础配置。
    • 在src/main/resources中新建文件:mybatis-config.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>
      <typeAliases>
      <typeAlias alias="City" type="jacob.domain.City" />
      </typeAliases>
      <environments default="development">
      <environment id="development">
      <transactionManager type="JDBC" />
      <dataSource type="POOLED">
      <property name="driver" value="com.mysql.jdbc.Driver" />
      <property name="url" value="jdbc:mysql://localhost:3306/world" />
      <property name="username" value="root" />
      <property name="password" value="111111" />
      </dataSource>
      </environment>
      </environments> <mappers>
      <mapper resource="jacob/mapper/city.xml" />
      </mappers>
      </configuration>
    • 逐一解释:

  3. 新建POJO,City。

    POJO的意思是:Plain Old Java Object,简单的说,就是一个普通的Java Bean。

    该Bean的内容对应于city表。

    文件如下:

     package jacob.domain;
    
     public class City {
    int id;
    String name;
    String countryCode;
    String district;
    int population; 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 String getCountryCode() {
    return countryCode;
    } public void setCountryCode(String countryCode) {
    this.countryCode = countryCode;
    } public String getDistrict() {
    return district;
    } public void setDistrict(String district) {
    this.district = district;
    } public int getPopulation() {
    return population;
    } public void setPopulation(int population) {
    this.population = population;
    } }
  4. 新建mapper文件:city.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="jacob.mapper.CityMapper">
    <resultMap type="City" id="CityResult">
    <id property="id" column="ID" />
    <result property="name" column="name" />
    <result property="countryCode" column="CountryCode" />
    <result property="district" column="District" />
    <result property="population" column="Population" />
    </resultMap>
    <select id="selectCity" parameterType="int" resultMap="CityResult">
    select *
    from city where id = #{id}
    </select> <select id="selectAll" resultType="City">
    select * from city;
    </select> </mapper>

    解释如下:

  5. 新建Interface,CityMapper,对应city.xml的方法。

    代码如下:

     package jacob.mapper;
    
     import java.util.List;
    
     import jacob.domain.City;
    
     public interface CityMapper {
    City selectCity(int id); List<City> selectAll();
    }
  6. 新建Class: CityService,并implemente CityMapper,实现各种方法。

    代码如下:

     package jacob.services;
    
     import java.util.List;
    
     import jacob.domain.City;
    import jacob.mapper.CityMapper;
    import jacob.mybatisdemo.MyBatisSqlSessionFactory; import org.apache.ibatis.session.SqlSession;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory; public class CityService implements CityMapper {
    private Logger logger = LoggerFactory.getLogger(getClass()); public City selectCity(int id) {
    SqlSession sqlSession = MyBatisSqlSessionFactory.openSession(); try {
    CityMapper cityMapper = sqlSession.getMapper(CityMapper.class);
    return cityMapper.selectCity(id);
    } finally {
    sqlSession.close();
    }
    } public List<City> selectAll() {
    SqlSession sqlSession = MyBatisSqlSessionFactory.openSession(); try {
    CityMapper cityMapper = sqlSession.getMapper(CityMapper.class);
    return cityMapper.selectAll();
    } finally {
    sqlSession.close();
    }
    }
    }
  7. 新建Class:MyBatisSqlSessionFactory,用户获取mybatis的session
     package jacob.mybatisdemo;
    
     import java.io.IOException;
    import java.io.InputStream; 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 MyBatisSqlSessionFactory { private static SqlSessionFactory sqlSessionFactory; public static SqlSessionFactory getSqlSessionFactory() {
    if (sqlSessionFactory == null) {
    InputStream inputStream;
    try {
    inputStream = Resources
    .getResourceAsStream("mybatis-config.xml");
    sqlSessionFactory = new SqlSessionFactoryBuilder()
    .build(inputStream);
    } catch (IOException e) {
    e.printStackTrace();
    }
    }
    return sqlSessionFactory;
    } public static SqlSession openSession(){
    return getSqlSessionFactory().openSession();
    } public static void main(String[] args) {
    // TODO Auto-generated method stub } }
  8. 新建测试文件,进行测试。

     package jacob.mybatisdemo;
    
     import java.util.List;
    
     import jacob.domain.City;
    import jacob.services.CityService; public class App {
    public static void main(String[] args) {
    CityService cityService = new CityService();
    City result = cityService.selectCity(2);
    System.out.println(result.getName()); List<City> list = cityService.selectAll();
    for (City c : list) {
    System.out.println(c.getName());
    }
    }
    }
  9. 输出结果:

文章以贴代码为主。工程下载地址:https://www.dropbox.com/s/w3j5jhy3lc12hzt/mybatisdemo.zip,请继续关注。

后续将整合spring,使用mybatis-generator来生成绝大多数的代码。

Mybatis基础入门 I的更多相关文章

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

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

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

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

  3. MyBatis基础入门《十八》动态SQL(if-where)

    MyBatis基础入门<十八>动态SQL(if-where) 描述: 代码是在<MyBatis基础入门<十七>动态SQL>基础上进行改造的,不再贴所有代码,仅贴改动 ...

  4. MyBatis基础入门《十七》动态SQL

    MyBatis基础入门<十七>动态SQL 描述: >> 完成多条件查询等逻辑实现 >> 用于实现动态SQL的元素主要有: > if > trim > ...

  5. MyBatis基础入门《十六》缓存

    MyBatis基础入门<十六>缓存 >> 一级缓存 >> 二级缓存 >> MyBatis的全局cache配置 >> 在Mapper XML文 ...

  6. MyBatis基础入门《十五》ResultMap子元素(collection)

    MyBatis基础入门<十五>ResultMap子元素(collection) 描述: 见<MyBatis基础入门<十四>ResultMap子元素(association ...

  7. MyBatis基础入门《十四》ResultMap子元素(association )

    MyBatis基础入门<十四>ResultMap子元素(association ) 1. id: >> 一般对应数据库中改行的主键ID,设置此项可以提高Mybatis的性能 2 ...

  8. MyBatis基础入门《十三》批量新增数据

    MyBatis基础入门<十三>批量新增数据 批量新增数据方式1:(数据小于一万) xml文件 接口: 测试方法: 测试结果: =============================== ...

  9. MyBatis基础入门《十二》删除数据 - @Param参数

    MyBatis基础入门<十二>删除数据 - @Param参数 描述: 删除数据,这里使用了@Param这个注解,其实在代码中,不使用这个注解也可以的.只是为了学习这个@Param注解,为此 ...

  10. MyBatis基础入门《十 一》修改数据

    MyBatis基础入门<十 一>修改数据 实体类: 接口类: xml文件: 测试类: 测试结果: 数据库: 如有问题,欢迎纠正!!! 如有转载,请标明源处:https://www.cnbl ...

随机推荐

  1. http://www.cnblogs.com/stephen-liu74/archive/2012/08/01/2561557.html

    http://www.cnblogs.com/stephen-liu74/archive/2012/08/01/2561557.html

  2. push() & concat()

    eg. var arr = []; arr.push(1); arr.push([2, 3]); arr.push(4, 5); arr = arr.concat(6); arr = arr.conc ...

  3. css3弹性盒模型(Flexbox)

    Flexbox是布局模块,而不是一个简单的属性,它包含父元素和子元素的属性. Flexbox布局的主体思想是似的元素可以改变大小以适应可用空间,当可用空间变大,Flex元素将伸展大小以填充可用空间,当 ...

  4. redis怎么动态添加内存,动态配置,无需重启。

    在redis的使用过程中,有时候需要急需修改redis的配置,比如在业务运行的情况下,内存不够怎么办,这时要么赶紧删除无用的内存,要么扩展内存.如果有无用的内容可删除那么所有问题都已经解决.如果内容都 ...

  5. libevent evbuffer bug

    今天发现 libevent 2.0.22 一个坑爹的bug,导致消息混乱.查找问题浪费一天,复现代码如下 #include <event2/buffer.h> #include <s ...

  6. c语言_常见图片格式判断

    c语言_常见图片格式判断 我想尽各种思路.今天,终于把图片判断搞定了. 在此,我写一下我的思路.希望对那些不想看代码的朋友们有帮助. 常风的的图片格式有:bmp,png,jpg,gif等图片格式. 我 ...

  7. 网易云课堂_C++程序设计入门(上)_第1单元:C++概览_第1单元作业 - 写代码 - 互评 (难度:易)

    第1单元作业 - 写代码 - 互评 (难度:易) 查看帮助 返回   提交作业(截止时间已过) 完成并提交作业     作业批改 互评训练   互评作业   自评作业     成绩公布 查看成绩 温 ...

  8. 图片延迟加载并等比缩放,一个简单的JQuery插件

    使用方法: $(".viewArea img").zoom({height:74,width:103}); (function($){ $.fn.zoom = function(s ...

  9. SpringMVC中采用简洁的配置实现文件上传

    文件上传我们一般会有两种策略,一种是通过IO流上传,还有一种是通过表单上传,其实这两种在客户端实现起来都是很简单的,在服务端处理会略有差别,个人感觉IO上传代码简单,但是也有很多硬伤,还是表单上传更合 ...

  10. SQL查询练习题目

    SQL查询练习题目 设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表(四)所示 ...