interlij idea创建给Web项目添加Mybatis

0、相关知识

  MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
每个MyBatis应用程序主要都是使用SqlSessionFactory实例的,一个SqlSessionFactory实例可以通过SqlSessionFactoryBuilder获得。SqlSessionFactoryBuilder可以从一个xml配置文件或者一个预定义的配置类的实例获得。
—摘自百度百科
  其实要说的是Mybatis和Hibernate的一点区别,两个都是优秀的ORM框架,用过之后,感觉都很不错,但是Hibernate对于复制的SQL语句的支持有限,而Mybatis的不像Hibernate是用HQL,而是直接用SQL语句,需要接触数据库,需要知道数据库细节,但是同时也能更好的使用数据库的复杂查询。
Hibernate也能直接通过session获得数据库对象来操作操作复杂查询的,但是这样做,与Hibernate的初衷有点违背而已。

1、系统环境

IDE:InterliJ IDEA 2017.1.4
jdk版本:1.8
Maven版本:3.5
MyBatis版本:3.X
数据库:MySQL 5.7 包含user表的sql脚本

2、添加Mybatis

创建一个maven项目,并添加tomcat服务器。

具体添加可以参考:interlij idea创建给Web项目添加Hibernate的创建项目和发布项目步骤。

接着添加如下依赖:

        
        <dependency>
            <groupId>javax.servletgroupId>
            <artifactId>javax.servlet-apiartifactId>
            <version>4.0.0-b01version>
        dependency>

        
        <dependency>
            <groupId>mysqlgroupId>
            <artifactId>mysql-connector-javaartifactId>
            <version>6.0.6version>
        dependency>

        
        <dependency>
            <groupId>org.mybatisgroupId>
            <artifactId>mybatisartifactId>
            <version>3.4.4version>
        dependency>

        
        <dependency>
            <groupId>junitgroupId>
            <artifactId>junitartifactId>
            <version>4.12version>
            <scope>testscope>
        dependency>

添加Mybatis插件:

菜单:File->settings

interlij idea创建给Web项目添加Mybatis_第1张图片

具体添加:搜索栏输入MyBatisCodeHelper接着点下面的Browse repositorys在线查找。

添加Mybatis配置文件模板(创建一次,以后直接新建就行了)

interlij idea创建给Web项目添加Mybatis_第2张图片

interlij idea创建给Web项目添加Mybatis_第3张图片

模板内容:




<configuration>

    <settings>
        
        <setting name="returnInstanceForEmptyRow" value="true"/>
    settings>

    <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/networkalbum?serverTimezone=GMT%2B8"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            dataSource>
        environment>
    environments>

    <mappers>

    mappers>
configuration>

interlij idea创建给Web项目添加Mybatis_第4张图片

新建实体类

package POJO;

import java.util.Date;

/**
 * Created by hui on 2017/6/17.
 */
public class User {

    private int id;
    private String name;
    private Date birth;
    private Integer sex;
    private Integer age;
    private String phone;
    private String email;
    private String pwd;

  // 各属性getter和setter方法省略,toString方法

interlij idea创建给Web项目添加Mybatis_第5张图片

interlij idea创建给Web项目添加Mybatis_第6张图片

关联一下mapper和config文件,在Mybatis-config.xm添加如下:

    <mappers>
        <mapper resource="UserDao.xml">mapper>
    mappers>

在UserDAO.xml添加如下:

    <select id="getUserById" resultType="POJO.User">
        SELECT * FROM USER WHERE id = #{id};
    select>

在UserDAO.java添加如下:

    //使用xml配置文件
    User getUserById(int id);
    //不使用配置文件使用注解
    @Select("Select * from user where id = #{id}")
    User getUserByIdForAnnotation(int id);

interlij idea创建给Web项目添加Mybatis_第7张图片

这里写图片描述

编写单元测试

代码如下:

public class UserDAOTest {
    @org.junit.Test
    public void Test(){
        String resourse = "Mybatis-config.xml";
        InputStream inputStream =null;
        try {
            inputStream = Resources.getResourceAsStream(resourse);
        } catch (IOException e) {
            e.printStackTrace();
        }
        if(inputStream==null){
            System.out.println("xml is null");
        }
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        SqlSession session = sqlSessionFactory.openSession();
        UserDao userDao = session.getMapper(UserDao.class);
        User user = userDao.getUserById(1);
        System.out.println(user.toString());

        User user2 = userDao.getUserByIdForAnnotation(2);
        System.out.println(user2.toString());
    }
}

interlij idea创建给Web项目添加Mybatis_第8张图片

如果junit单元测试报错,那么写jsp调试错误吧,junit并没给出多少错误信息。
你可以吧index.jsp改成这样子

<%@ page import="java.io.InputStream" %>
<%@ page import="org.apache.ibatis.io.Resources" %>
<%@ page import="java.io.IOException" %>
<%@ page import="org.apache.ibatis.session.SqlSessionFactory" %>
<%@ page import="org.apache.ibatis.session.SqlSessionFactoryBuilder" %>
<%@ page import="org.apache.ibatis.session.SqlSession" %>
<%@ page import="POJO.UserDao" %>
<%@ page import="POJO.User" %>
<html>
<body>
<h2>Hello World!h2>
<%
    String resourse = "MyBatis-config.xml";
    InputStream inputStream =null;
    try {
        inputStream = Resources.getResourceAsStream(resourse);
    } catch (IOException e) {
        e.printStackTrace();
    }
    if(inputStream==null){
        System.out.println("xml is null");
    }
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
    SqlSession sessionz = sqlSessionFactory.openSession();
    UserDao userDao = sessionz.getMapper(UserDao.class);
    User user = userDao.getUserById(1);
    System.out.println(user.toString());

    User user2 = userDao.getUserByIdForAnnotation(2);
    System.out.println(user2.toString());

%>
body>
html>

你可能感兴趣的:(java)