MyBatis框架

来源:互联网 发布:58 程序员兼职 编辑:程序博客网 时间:2024/05/18 11:15

平时我们都用JDBC访问数据库,除了需要自己写SQL外,还必须操作Connection,Statment,ResultSet这些只是手段的辅助类。不仅如此,访问不同的表,还会写很多雷同的代码,显得繁琐和枯燥。

那么用了MyBatis之后,只需自己提供SQL语句,其他工作,例如建立连接,Statment,JDBC相关异常处理等等都交给MyBatis去做了,那些重复性的工作MyBatis也给做了,我们只需要关注在增删改查等操作层面上,而把技术细节都封装在了我们看不见的地方。


步骤一:学习之前先看效果

步骤二:创建数据库

步骤三:创建表

步骤四:导入数据

步骤五:创建项目

步骤六:导入jar包

步骤七:创建实体类

步骤八:配置文件:mybatis-config.xml

步骤九:配置文件:Category.xml

步骤十:测试类:TestMybatis

步骤十一:基本原理图

步骤十二:可运行的项目


步骤一:学习之前先看效果

这两条数据是通过mybatis从数据库中查出来的


步骤二:创建数据库

首先创建数据库how2java

create database how2java


步骤三:创建表

USE how2java; CREATE TABLE category_ (  id int(11) NOT NULL AUTO_INCREMENT,  name varchar(32) DEFAULT NULL,  PRIMARY KEY (id)) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8; 

步骤四:导入数据

USE how2java;INSERT INTO category_ VALUES (null,'category1');INSERT INTO category_ VALUES (null,'category2');
步骤五:创建项目
步骤六:导入jar包


步骤七:创建实体类


准备实体类Category,用于映射表category

package com.how2java.pojo; public class Category {    private int id;    private String name;    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;    }     }

步骤八:配置文件:mybatis-config.xml

在src目录下创建mybatis的主配置文件mybatis-config.xml。其作用主要是提供连接数据库用的驱动,数据库名称,编码方式,账号密码

<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/how2java?characterEncoding=UTF-8"/>
<property name="username" value="root"/>
<property name="password" value="admin"/>

以及别名,自动扫描com.how2java.pojo下的类型,使得在后续配置文件Category.xml中使用resultType的时候,可以直接使用Category,而不必写全com.how2java.pojo.Category

<typeAliases>
<package name="com.how2java.pojo"/>
</typeAliases>

映射Category.xml

<mappers>
<mapper resource="com/how2java/pojo/Category.xml"/>
</mappers>

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration>    <typeAliases>      <package name="com.how2java.pojo"/>    </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/how2java?characterEncoding=UTF-8"/>                <property name="username" value="root"/>                <property name="password" value="admin"/>            </dataSource>        </environment>    </environments>    <mappers>        <mapper resource="com/how2java/pojo/Category.xml"/>    </mappers></configuration>

步骤九:配置文件:Category.xml

在包com.how2java.pojo下,新建文件Category.xml

namespace="com.how2java.pojo"

表示命名空间是com.how2java.pojo,在后续调用sql语句时,会用到它。

里面定义了一条sql语句

select * from category_

这条sql语句用id:listCategory进行标示以供后续代码调用。resultType="Category"表示返回的数据和Category关联起来,这里本应该使用的是com.how2java.pojo.Category,但是因为上一步配置了别名,所以直接使用Category就行了

<?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.how2java.pojo">        <select id="listCategory" resultType="Category">            select * from   category_              </select>    </mapper>

步骤十:测试类:TestMybatis

运行并观察到如图所示的结果。

根据配置文件mybatis-config.xml得到sqlSessionFactory。

String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
然后再根据sqlSessionFactory得到session

SqlSession session=sqlSessionFactory.openSession();

最后通过session的selectList方法,调用sql语句listCategory。listCategory这个就是在配置文件Category.xml中那条sql语句设置的id.

执行完毕之后,得到一个Category集合,便利即可看到数据。

List<Category> cs = session.selectList("listCategory");
for (Category c : cs) {
System.out.println(c.getName());
}

注: session.selectList("listCategory");也可以写成session.selectList("com.how2java.pojo.listCategory");效果一样。

package com.how2java; import java.io.IOException;import java.io.InputStream;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 com.how2java.pojo.Category; public class TestMybatis {     public static void main(String[] args) throws IOException {        String resource = "mybatis-config.xml";        InputStream inputStream = Resources.getResourceAsStream(resource);        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);        SqlSession session=sqlSessionFactory.openSession();                 List<Category> cs=session.selectList("listCategory");        for (Category c : cs) {            System.out.println(c.getName());        }             }}

步骤十一:基本原理图

1.应用程序找Mybatis要数据

2.mybatis 从数据库中找来数据

   2.1  通过mybatis-config.xml定位哪个数据库

   2.2  通过Category.xml执行对应的select语句

   2.3  基于Category.xml把返回的数据库记录封装在Category对象中

   2.4  把多个Category对象装在一个Category集合中

3 返回一个Category集合



 
原创粉丝点击