MyBatis学习

Posted 相信光的奥特王小懒

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MyBatis学习相关的知识,希望对你有一定的参考价值。


MyBatis的学习

1.中文文档

https://mybatis.org/mybatis-3/zh/index.html

MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。
2013年11月迁移到Github。

MyBatis学习_mybatis

如何获取mybatis:

1.maven仓库

<!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>

2.github

https://github.com/mybatis/mybatis-3

2.持久层

Dao层,Service层,Controller层

3.学习过程

3.1 导入依赖

<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>

</dependencies>

3.2 创建模块

写一个核心配置文件

<?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>
<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/mybatis?useSSl=true&useUnicode=true&characterEncoding=utf-8"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="org/mybatis/example/BlogMapper.xml"/>
</mappers>
</configuration>

写一个工具类

package utils;

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 java.io.IOException;
import java.io.InputStream;

public class MyBatisUtil
private static SqlSessionFactory sqlSessionFactory;



static

try
//使用mybatis第一步获取sqlSession对象
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
catch (IOException e)
e.printStackTrace();



public static SqlSession getSqlSession()
SqlSession sqlSession=sqlSessionFactory.openSession();
return sqlSession;


实体类

package pojo;

public class User
private int id;
private String name;
private String pwd;

public User()


public User(int id, String name, String pwd)
this.id = id;
this.name = name;
this.pwd = pwd;


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 getPwd()
return pwd;


public void setPwd(String pwd)
this.pwd = pwd;



@Override
public String toString()
return "User" +
"id=" + id +
", name=" + name + \\ +
", pwd=" + pwd + \\ +
;

接口类

package dao;

import pojo.User;

import java.util.List;

//编写一个接口类
public interface UserDao
List<User> getUserList();

mybatis中直接通过xml文件连接数据库和实现接口类

MyBatis学习_sql_02

4.CRUD增删改查

需要注意的事:

namespace的包名要跟Dao和Mapper的接口的包名一致。

4.1 select

MyBatis学习_mybatis_03

4.2 insert

4.3 update

4.4 delete

******增删改需要提交事务

4.5 万能Map

如果一个实体类或者数据库的参数过多,我们应当考虑使用map

MyBatis学习_mybatis_04

MyBatis学习_apache_05

MyBatis学习_mybatis_06

Map传递参数,可以直接在sql中取出参数即可。

5 日志的实现

5.1默认的日志使用

MyBatis学习_java_07

MyBatis学习_java_08

5.2 LOG4J的使用

1.导入依赖

<!-- https://mvnrepository.com/artifact/log4j/log4j -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>

2.写一个log4j.properties

#将等级为DEBUG的日志信息输出到console和file这两个目的地,console和file的定义在下面的代码
log4j.rootLogger=DEBUG,console,file

#控制台输出的相关设置
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.Threshold=DEBUG
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=[%c]-%m%n

#文件输出的相关设置
log4j.appender.file = org.apache.log4j.RollingFileAppender
log4j.appender.file.File=./log/whx.log
log4j.appender.file.MaxFileSize=10mb
log4j.appender.file.Threshold=DEBUG
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=[%p][%dyy-MM-dd][%c]%m%n

#日志输出级别
log4j.logger.org.mybatis=DEBUG
log4j.logger.java.sql=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.ResultSet=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG

3.表示使用成功

MyBatis学习_sql_09

4.简单使用

MyBatis学习_apache_10

LOG4J的相关方法和配置的网址:
https://baike.baidu.com/item/log4j/480673?fr=aladdin#2

6 使用注解开发

1.注解在接口上实现

@select("select * from user")
List<User>getUsers();

2.需要在配置文件绑定接口

<mappers>
<mapper class="dao.UserMapper/>"
</mappers>

7.使用注解完成增删改查

不需要写xml文件直接在测试文件书写即可

1.根据ID查询用户

@Select("select * from mybatis.user where id=#id")
User getUserById(@Param("id") int id);

2.增加用户

@Insert("insert into mybatis.user (id,name,pwd)values(#id,#name,#pwd)")
int addUser(User user);

与xml文件进行对比

<select id="getUserById" resultType="pojo.User" parameterType="int">
select * from mybatis.user where id=#id
</select>


<insert id="addUser" parameterType="dao.UserMapper">
insert into mybatis.user (id,name,pwd)values (#id,#name,#pwd)
</insert>

方便快捷很多,但是只限于参数少的时候。

MyBatis学习_mybatis_11

使用注解得在配置文件中完成注册。

MyBatis学习_sql_12

若含有多个Mapper的时候我们可以采用resource字段

<mapper resource="dao/*Mapper.xml"></mapper>

@param注解:

1.基本类型的参数或者String必须加上

2.引用类型不需要加上

3.如果只有一个基本类型的话可以忽略,但是建议都加上

4.我们在SQL中引用的就是我们在@Param中设定的属性名

8.Lombok的学习

MyBatis学习_apache_13

简化实体类的书写。

Maven中需要导入的依赖:https://mvnrepository.com/artifact/org.projectlombok/lombok/1.18.20

9.多对一处理

9.1按照结果嵌套处理

MyBatis学习_mybatis_14

9.2 按照select内嵌查询

MyBatis学习_java_15

<select id="getStudentList" resultMap="StudentTeacher">
select * from mybatis.student
</select>
<resultMap id="StudentTeacher" type="pojo.Student">
<result property="id" column="id"></result>
<result property="name" column="name"></result>

<association property="teacher" column="tid" javaType="pojo.Teacher" select="getTeacherById"></association>
</resultMap>

<select id="getTeacherById" resultType="pojo.Teacher">
select * from mybatis.teacher where id=#id
</select>

10.一对多处理

此处举例为一个老师对应多个学生

1.实体类

package pojo;
import lombok.Data;
@Data
public class Student
private int id;
private String name;
private int tid;

package pojo;
import lombok.Data;
import java.util.List;
@Data
public class Teacher
private int id;
private String name;

// 一个老师对应多个学生
private List<Student> students;

接口类

package dao;

import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import pojo.Teacher;

import java.util.List;

public interface TeacherMapper
//查询老师信息
// List<Teacher> getTeacher();


// 获取指定老师下的所有学生
Teacher getTeacherById(@Param("tid") int id);

10.1 按select嵌套查询

MyBatis学习_sql_16

10.2 按结果嵌套查询

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="dao.TeacherMapper">

<select id="getTeacherById" resultMap="TeacherStudent">
select s.id sid,s.name sname,t.name tname,t.id tid from student s,teacher t where s.tid=t.id and t.id=#tid
</select>
<resultMap id="TeacherStudent" type="pojo.Teacher">
<result property="id" column="tid"></result>
<result property="name" column="tname"></result>
<collection property="students" ofType="pojo.Student">
<result property="id" column="sid"></result>
<result property="name" column="sname"></result>
<result property="tid" column="tid"></result>
</collection>
</resultMap>

小结:

关联 association (多对一)

集合 collection(一对多)

MyBatis学习_mybatis_17

MyBatis学习_java_18

11.动态SQL

创建一个基础工程:
1.导包
2.编写配置文件
3.编写一个实体类
4.编写实体类对应的Mapper以及Mapper.xml文件

解决驼峰命名,例如数据库字段为create_time而实体类中写的是createTime这种形式,在settings中设置为true.

MyBatis学习_mybatis_19

配置文件

<?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>
<settings>
<setting name="mapUnderscoreToCamelCase" 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/mybatis?useSSl=true&useUnicode=true&characterEncoding=utf-8"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>

<mappers>
<mapper class="dao.BlogMapper"></mapper>
</mappers>
</configuration>

BlogMapper文件

package dao;

import pojo.Blog;

public interface BlogMapper

int addBlog(Blog blog);

BlogMapper.xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="dao.BlogMapper">

<insert id="addBlog" parameterType="dao.BlogMapper">
insert into mybatis.blog (id,title,author,create_time,views)values (#id,#title,#author,#createTime,#views)
</insert>

</mapper>

测试文件

import dao.BlogMapper;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import pojo.Blog;
import utils.IDutils;
import utils.MyBatisUtil;

import java.util.Date;

public class MyTest
@Test
public void addBlog()
SqlSession sqlSession = MyBatisUtil.getSqlSession();
BlogMapper mapper = sqlSession.getMapper(BlogMapper.class);
Blog blog=new Blog();
blog.setId(IDutils.getId());
blog.setTitle("一日归属吉大,一生念念不忘");
blog.setAuthor("吉林大学王小懒");
blog.setCreateTime(new Date());
blog.setViews(9999);
mapper.addBlog(blog);

blog.setId(IDutils.getId());
blog.setTitle("java学习很简单");
mapper.addBlog(blog);

blog.setId(IDutils.getId());
blog.setTitle("python学习很简单");
mapper.addBlog(blog);

sqlSession.commit();
sqlSession.close();

11.1 动态SQL之IF语句

<select id="queryBlogIf" parameterType="map" resultType="pojo.Blog">
select * from mybatis.blog where 1=1
<if test="title!=null">
and title=#title
</if>
<if test="author!=null">
and author=#author
</if>
</select>

如果没有where 1=1则程序会报错,此种错误的解决方式是加一个where标签。如下:

<select id="queryBlogIf" parameterType="map" resultType="pojo.Blog">
select * from mybatis.blog
<where>
<if test="title!=null">
and title=#title
</if>
<if test="author!=null">
author=#author
</if>
</where>
</select>

11.2trim(where和set)

<select id="queryBlogIf" parameterType="map" resultType="pojo.Blog">
select * from mybatis.blog
<where>
<if test="title!=null">
and title=#title
</if>
<if test="author!=null">
author=#author
</if>
</where>
</select>

MyBatis学习_sql_20

MyBatis学习_sql_21

11.3 SQL片段

1.使用SQL片段提取公共部分。

2.在需要使用的地方通过include的标签引用即可。

<sql id="if-title-author">

<if test="title != null">
title = #title
</if>

<if test="author != null">
and author = #author

</if>
</sql>
<select id="queryBlogIF" parameterType="map" resultType="blog">
select * from mybatis.blog
<where>
<include refid="if-title-author"></include>
</where>
</select>

MyBatis学习_apache_22

开启别名的Settings的设置:

MyBatis学习_java_23



以上是关于MyBatis学习的主要内容,如果未能解决你的问题,请参考以下文章

mybatis-plus配置返回map自动转换为驼峰

SpringBoot+Mybatis关于开启驼峰映射的设置

Mybatis处理列名—字段名映射— 驼峰式命名映射

mybatis支持属性使用驼峰的命名

MyBatis驼峰命名方法问题解决方法

mybatis 支持属性使用驼峰的命名 返回map为啥不支持