Mybatis—基础

Mybatis是一个优秀的持久层框架,支持自定义SQL、存储过程和高级映射。本文详细介绍了在Maven项目中集成Mybatis的步骤,包括创建数据库、配置依赖、编写配置文件、创建实体类和Mapper接口,以及如何进行增删改查操作。此外,还提到了Mybatis的环境配置、类型别名、结果映射和日志配置。
摘要由CSDN通过智能技术生成

Mybatis

一、Mybatis简介

  • MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。
  • MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。
  • MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

二、在Maven项目中使用Mybatis

  1. 创建数据库以及表

  2. 创建一个普通的maven项目

  3. 安装依赖

    • mysql驱动:mysql-connector-java
    • mybatis
  4. 编写mybatis核心配置文件

  5. 编写mybatis工具类(用来加载核心配置文件和返回一个sqlSession)

  6. 创建具体的实体类和Mapper接口

  7. 创建对应的Mapper接口类的xml文件,实现对应方法的sql语句;(这里也可以在Mapper接口类上对应的方法使用注解完成sql语句,但sql语句复杂的话,使用注解不好操作)

    注意点:

    • 一般将xml或者properties文件放在resources目录下

    • 如果将将xml或者properties文件放在java目录下,会在导出的时候无法加载到,需要在pom.xml文件里面配置以下代码

       <build>
              <resources>
                  <resource>
                      <directory>src/main/resources</directory>
                      <includes>
                          <include>**/*.properties</include>
                          <include>**/*.xml</include>
                      </includes>
                      <filtering>true</filtering>
                  </resource>
                  <resource>
                      <directory>src/main/java</directory>
                      <includes>
                          <include>**/*.properties</include>
                          <include>**/*.xml</include>
                      </includes>
                      <filtering>true</filtering>
                  </resource>
              </resources>
          </build>
      
  8. 编写测试,需要导入依赖 junit

1. 创建数据库以及表
create database mybatis_test;
use mybatis_test;
create table user(
    id int not null auto_increment,
    username varchar(30) not null ,
    password varchar(30) not null ,
    primary key (id)
);
insert into user(username, password) values ('小陈','123456'),('小红','123456');
2. 创建普通的maven项目

在这里插入图片描述
在这里插入图片描述

可以创建父子项目,就在一个普通的maven项目里面(把其src目录删了),创建module(新建maven子项目),这样就可以在一个项目里面创建多个子项目

3. 安装依赖

在pom.xml文件里面写依赖,可以到maven仓库官网查看依赖

<dependencies>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.11</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.47</version>
    </dependency>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.9</version>
    </dependency>
</dependencies>
4. 编写mybatis核心配置文件

mybatis官网查看,在resources目录下创建一个mybatis-config.xml文件并配置好数据库信息。

XML 配置文件中包含了对 MyBatis 系统的核心设置,包括获取数据库连接实例的数据源(DataSource)以及决定事务作用域和控制方式的事务管理器(TransactionManager)

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>
    <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_test?useUnicode=true&amp;characterEncoding=UTF-8"/>
                <property name="username" value="root"/>
                <property name="password" value="134679"/>
            </dataSource>
        </environment>
    </environments>
</configuration>
5. 编写mybatis工具类

在java目录下,创建一个com.组织名.utilts包,创建一个MybatisUtil.java文件

package com.suzezhi.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=null;
    //让以下代码进来就初始化
    static {
        String resource = "mybatis-config.xml";
        InputStream inputStream = null;
        try {
            inputStream = Resources.getResourceAsStream(resource);
        } catch (IOException e) {
            e.printStackTrace();
        }
        sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
    }
    //返回一个SqlSession对象,操作sql需要用到
    public static SqlSession getSqlSession(){
        return sqlSessionFactory.openSession();
    }
}

6. 创建具体的实体类和Mapper接口

在java目录下创建两个包,pojo(用来存放实体类,实体类名称和属性与数据表对应),mapper包(用来存放业务逻辑)

在这里插入图片描述

在pojo包下创建User.java文件

package com.suzezhi.pojo;

public class User {
    private int id;
    private String username;
    private String password;

    public User() {
    }

    public User(int id, String username, String password) {
        this.id = id;
        this.username = username;
        this.password = password;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
}

属性与数据库表的列名一一对应

在这里插入图片描述

在mapper包下,创建接口UserMapper.java

package com.suzezhi.mapper;

import com.suzezhi.pojo.User;

import java.util.List;

public interface UserMapper {
    //获取用户信息,在usermapper.xml文件中实现sql查询
    List<User> getUserList();
}

7.创建xml文件

每个xxxMapper接口都对应一个xxxMapper.xml文件,作接口方法的sql实现

这里我直接在resources目录下创建mapper目录来创建xml文件,所以pom.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.suzezhi.mapper.UserMapper">
<!--    编写sql配置 id的值是接口里面方法名称 返回类型与方法的返回类型一致-->
    <select id="getUserList" resultType="com.suzezhi.pojo.User">
        select * from user;
    </select>
</mapper>

每个创建的xxxMapper.xml文件都需要到mybatis-config.xml核心配置文件中进行注册

<!--    注册每一个mapper.xml文件-->
    <mappers>
        <mapper resource="mapper/userMapper.xml"></mapper>
    </mappers>
8.编辑测试

在test的java目录下,创建与src目录java目录相同的包名来写测试类(只是建议和规范)

package com.suzezhi.mapper;

import com.suzezhi.pojo.User;
import com.suzezhi.utils.MybatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

import java.util.List;

public class TestUserMapper {
    @Test
    public void test(){
        //获取sqlsession对象
        SqlSession sqlSession = MybatisUtil.getSqlSession();
        //获取mapper接口类
        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
        //调用方法执行其对应的sql
        List<User> userList = userMapper.getUserList();

        //打印内容
        for (User user : userList) {
            System.out.println(user);
        }
        
        //关闭sqlsession
        sqlSession.close();
    }
}

三、增删改查

1. select
//UserMapper.java
//根据id过去用户信息
User getUserById(int id);
<!--userMapper.xml-->
<!--    通过id查询用户  parameterType参数类型-->
<select id="getUserById" parameterType="int" resultType="com.suzezhi.pojo.User">
    select * from user where id=#{id};
</select>

测试方法

//通过id查询用户
@Test
public void getUserById(){
    SqlSession sqlSession = MybatisUtil.getSqlSession();
    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
    User userById = userMapper.getUserById(1);
    System.out.println(userById);
    sqlSession.close();
}
2.insert
//UserMapper.java
//添加一个用户
int addUser(User user);
<!--userMapper.xml-->
<!--    添加用户-->
<insert id="addUser" parameterType="com.suzezhi.pojo.User">
    insert into user(username,password) values (#{username},#{password});
</insert>

测试方法

//添加用户
@Test
public void addUser(){
    SqlSession sqlSession = MybatisUtil.getSqlSession();
    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
    User user = new User();
    user.setUsername("天明");
    user.setPassword("123456");
    int i = userMapper.addUser(user);
    //提交事务,否则添加不成功
    sqlSession.commit();
    sqlSession.close();
}
3.update
//UserMapper.java
//通过用户名来更新密码
int updateUserByName(User user);
<!--userMapper.xml-->
<!--    更改用户信息-->
<update id="updateUserByName" parameterType="com.suzezhi.pojo.User">
    update user set password=#{password} where username=#{username};
</update>

测试方法

//更新用户信息
@Test
public void updateUserByName(){
    SqlSession sqlSession = MybatisUtil.getSqlSession();
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    User user = new User();
    user.setUsername("天明");
    user.setPassword("2132323232344");
    int i = mapper.updateUserByName(user);
    //提交事务
    sqlSession.commit();
    sqlSession.close();
}
4. delete
//UserMapper.java
//通过id删除用户
int delUserById(int id);
<!--userMapper.xml-->
<!--    根据id删除用户-->
<delete id="delUserById" parameterType="int">
    delete from user where id=#{id};
</delete>

测试方法

//根据id删除用户
@Test
public void delUserById(){
    SqlSession sqlSession = MybatisUtil.getSqlSession();
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    int i = mapper.delUserById(4);
    //提交事务
    sqlSession.commit();
    sqlSession.close();
}
注意

insert,delete,update三种操作需要提交事务sqlSession.commit();否则数据无法修改成功

四、Mybatis配置

MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息。 配置文档的顶层结构如下(xml的顺序):

configuration(配置)

1. properties属性

这些属性可以在外部进行配置,并可以进行动态替换。你既可以在典型的 Java 属性文件中配置这些属性,也可以在 properties 元素的子元素中设置

db.properties配置文件,配置连接数据库的相关内容

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis_test?useUnicode=true&characterEncoding=UTF-8
username=root
password=134679
<!-- 加载外部配置文件 -->
<properties resource="db.properties">
    <!-- 添加属性,外部配置文件没有则会使用这里的属性 -->
    <property name="username" value="root"/>
</properties>
<environments default="development">
    <environment id="development">
        <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>

注意:

如果一个属性在不只一个地方进行了配置,那么,MyBatis 将按照下面的顺序来加载:

  • 首先读取在 properties 元素体内指定的属性。
  • 然后根据 properties 元素中的 resource 属性读取类路径下属性文件,或根据 url 属性指定的路径读取属性文件,并覆盖之前读取过的同名属性。
  • 最后读取作为方法参数传递的属性,并覆盖之前读取过的同名属性。

因此,通过方法参数传递的属性具有最高优先级,resource/url 属性中指定的配置文件次之,最低优先级的则是 properties 元素中指定的属性。

2. 环境配置

MyBatis 可以配置成适应多种环境,这种机制有助于将 SQL 映射应用于多种数据库之中, 现实情况下有多种理由需要这么做。例如,开发、测试和生产环境需要有不同的配置;或者想在具有相同 Schema 的多个生产数据库中使用相同的 SQL 映射。还有许多类似的使用场景。

不过要记住:尽管可以配置多个环境,但每个 SqlSessionFactory 实例只能选择一种环境。

注意:

  • 默认使用的环境 ID(比如:default=“development”)。
  • 每个 environment 元素定义的环境 ID(比如:id=“development”)。
  • 事务管理器的配置(比如:type=“JDBC”)。
  • 数据源的配置(比如:type=“POOLED”)。

默认环境和环境 ID 顾名思义。 环境可以随意命名,但务必保证默认的环境 ID 要匹配其中一个环境 ID。

3.类型别名typeAliases

类型别名可为 Java 类型设置一个缩写名字。 它仅用于 XML 配置,意在降低冗余的全限定类名书写

方式一:

mybatis-config.xml(mybatis的核心配置文件)

<typeAliases>
    <!-- com.suzezhi.pojo.User实体类起别名User,在xxxMapper.xml中那些类型返回值就可以使用别名了 -->
  <typeAlias alias="User" type="com.suzezhi.pojo.User"/>
</typeAliases>

userMapper.xml文件

<!--没用别名的:    编写sql配置 id的值是接口里面方法名称 返回类型与方法的返回类型一致-->
<select id="getUserList" resultType="com.suzezhi.pojo.User">
    select * from user;
</select>

<!--使用别名的:    编写sql配置 id的值是接口里面方法名称 返回类型与方法的返回类型一致-->
<select id="getUserList" resultType="User">
    select * from user;
</select>

方式二:

也可以指定一个包名,MyBatis 会在包名下面搜索需要的 Java Bean

<typeAliases>
  <package name="com.suzezhi.pojo.User"/>
</typeAliases>

每一个在包 com.suzezhi.pojo 中的 Java Bean,在没有注解的情况下,会使用 Bean 的首字母小写的非限定类名来作为它的别名。 比如 com.suzezhi.pojo.User 的别名为 user;若有注解,则别名为其注解值。注解在其实体类上添加@Alias("别名")

<!--使用别名的:    编写sql配置 id的值是接口里面方法名称 返回类型与方法的返回类型一致-->
<select id="getUserList" resultType="user">
    select * from user;
</select>
4. 映射器mappers

既然 MyBatis 的行为已经由上述元素配置完了,我们现在就要来定义 SQL 映射语句了。 但首先,我们需要告诉 MyBatis 到哪里去找到这些语句。 在自动查找资源方面,Java 并没有提供一个很好的解决方案,所以最好的办法是直接告诉 MyBatis 到哪里去找映射文件。

在resources目录下写的xml文件,只能使用方式一

mybatis-config.xml配置文件

方式一:

<!-- 使用相对于类路径的资源引用 -->
<mappers>
  <mapper resource="mapper/userMapper.xml"/>
</mappers>

方式二:

<!-- 使用映射器接口实现类的完全限定类名 -->
<mappers>
  <mapper class="com.suzezhi.mapper.UserMapper"/>
</mappers>

方式三:

<!-- 将包内的映射器接口实现全部注册为映射器 -->
<mappers>
  <package name="com.suzezhi.mapper"/>
</mappers>

方式二和方式三需要注意以下

  • xml文件与接口类名字一致
  • xml文件与接口类放在同一个包下

五、结果映射resultMap

在为一些比如连接的复杂语句编写映射代码的时候,一份 resultMap 能够代替实现同等功能的数千行代码。ResultMap 的设计思想是,对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了。

字段属性映射

实体类的属性与数据库表的列名不一致问题,在对应的xxxMapeer.xml就会显示这个字段为null。

在这里插入图片描述

//User01Mapper接口
package com.suzezhi.mapper;

import com.suzezhi.pojo.User01;

public interface User01Mapper {
//    通过id查询用户信息
    User01 getUserById(int id);
}
<!-- user01Mapper.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.suzezhi.mapper.User01Mapper">
<!--    user01是com.suzezhi.pojo.User01的别名-->
    <select id="getUserById" resultType="user01">
        select * from USER where id=#{id};
    </select>
</mapper>

测试方法

package com.suzezhi.mapper;

import com.suzezhi.pojo.User01;
import com.suzezhi.utils.MybatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

public class TestUser01Mapper {
    @Test
    public void getUserById(){
        SqlSession sqlSession = MybatisUtil.getSqlSession();
        User01Mapper mapper = sqlSession.getMapper(User01Mapper.class);
        User01 userById = mapper.getUserById(6);
        System.out.println(userById);
        sqlSession.close();
    }
}

结果

在这里插入图片描述

原因:select * from USER where id=6;,会查询id,username,password,email这四个列,而自定义的方法返回值是User,里面的name,pwd属性没有找到列名,相当于查找``select id,name,pwd,email from USER where id=6`,user表没有name和pwd这两个列名所以返回了null。

解决方法

方式一:使用别名

<!--    user01是com.suzezhi.pojo.User01的别名-->
    <select id="getUserById" resultType="user01">
        select id,username as name,password as pwd,email from USER where id=#{id};
    </select>

方式二:使用resultMap,映射实体类属性名与表名,只需映射不一致的即可

<?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.suzezhi.mapper.User01Mapper">
    <!--    user01是com.suzezhi.pojo.User01的别名 id供下面的select返回类型使用-->
    <resultMap id="resultmap" type="user01">
        <!-- property的值对应实体类的属性名,column的值对应其映射到数据表的列名 -->
        <result property="name" column="username"></result>
        <result property="pwd" column="password"></result>
    </resultMap>
<!--    不使用resultType 而使用resultMap,其值是上面resultMap的id -->
    <select id="getUserById" resultMap="resultmap">
        select * from USER where id=#{id};
    </select>
</mapper>
高级映射方式
  1. 创建一个学生表和教师表
  2. 创建对应的实体类
  3. 编写接口方法
  4. 实现xml的sql实现
  5. 测试

数据库

-- 创建教师表
CREATE TABLE `teacher` (
  `id` int(11) NOT NULL,
  `tname` varchar(20) NOT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `id` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into teacher(id,tname) values(1,"老陈");

-- 创建学生表
CREATE TABLE `student` (
  `id` int(11) NOT NULL,
  `sname` varchar(20) NOT NULL,
  `tid` int(11) NOT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `id` (`id`),
  KEY `tid` (`tid`),
  CONSTRAINT `student_ibfk_1` FOREIGN KEY (`tid`) REFERENCES `teacher` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

insert into student(id,sname,tid) values(1,'小陈',1),(2,'小红',1);

实体类

// Student.java
package com.suzezhi.pojo;

public class Student {
    private int id;
    private String sname;
    //学生表的tid来自于教师,所以通过组合来写
    private Teacher teacher;

    public Student() {
    }

    public Student(int id, String sname, Teacher teacher) {
        this.id = id;
        this.sname = sname;
        this.teacher = teacher;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getSname() {
        return sname;
    }

    public void setSname(String sname) {
        this.sname = sname;
    }

    public Teacher getTeacher() {
        return teacher;
    }

    public void setTeacher(Teacher teacher) {
        this.teacher = teacher;
    }

    @Override
    public String toString() {
        return "Student{" +
                "id=" + id +
                ", sname='" + sname + '\'' +
                ", teacher=" + teacher +
                '}';
    }
}

//Teacher.java
package com.suzezhi.pojo;

public class Teacher {
    private int id;
    private String tname;

    public Teacher() {
    }

    public Teacher(int id, String tname) {
        this.id = id;
        this.tname = tname;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getTname() {
        return tname;
    }

    public void setTname(String tname) {
        this.tname = tname;
    }

    @Override
    public String toString() {
        return "Teacher{" +
                "id=" + id +
                ", tname='" + tname + '\'' +
                '}';
    }
}

接口逻辑

package com.suzezhi.mapper;

import com.suzezhi.pojo.Student;
import com.suzezhi.pojo.Teacher;

import java.util.List;

public interface StudentMapper {
    //多对一处理,学生对应老师
    List<Student> getStudentInfo();
    //通过id来查找老师
    Teacher getTeacherById(int tid);
}

实现方式如下:

方式一(采用子查询)
<!--StudentMapper.xml-->
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.suzezhi.mapper.StudentMapper">
<!--    方式一:使用子查询-->
    <select id="getStudentInfo" resultMap="StudentAndTeacher">
        select * from student;
    </select>
    <resultMap id="StudentAndTeacher" type="student">
        <result property="id" column="id"></result>
        <result property="sname" column="sname"></result>
<!--        复杂的属性,需要单独处理 对象:association   集合:collection -->
<!--        select="getTeacherById"让其调用id为getTeacherById的select查询-->
        <association property="teacher" column="tid" javaType="Teacher" select="getTeacherById"></association>
    </resultMap>
    <select id="getTeacherById" parameterType="int" resultType="Teacher">
        select * from teacher where id=#{tid}
    </select>
</mapper>
方式二(采用联表查询)
<!--    方式二: 联表查询-->
<select id="getStudentInfo" resultMap="StudentAndTeacher">
    select s.id sid,s.sname sname,t.id,t.tname from student s,teacher t where s.tid=t.id;
</select>
<resultMap id="StudentAndTeacher" type="student">
    <result property="id" column="sid"></result>
    <result property="sname" column="sname"></result>
    <association property="teacher" javaType="Teacher">
        <result property="tname" column="tname"></result>
    </association>
</resultMap>

测试代码

import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import com.suzezhi.mapper.StudentMapper;
import com.suzezhi.pojo.Student;
import com.suzezhi.utils.MybatisUtil;

import java.util.List;

public class MyTest {
    @Test
    public void getStudentInfo(){
        SqlSession sqlSession = MybatisUtil.getSqlSession();
        StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);
        List<Student> studentInfo = mapper.getStudentInfo();
        for (Student student : studentInfo) {
            System.out.println(student);
        }
        sqlSession.close();
    }
}

对象(多对一):association ,类型使用javaType指定泛型

集合(一对多):collection,类型使用ofType指定泛型

六、日志(log4j)

  • Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;
  • 我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。

步骤:

  1. 导入log4j包
  2. 编写log4j.properties配置文件
  3. 使用log4j
1. 导入log4j依赖包
<!-- https://mvnrepository.com/artifact/log4j/log4j -->
<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>

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

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

#文件输出的相关设置
log4j.appender.file = org.apache.log4j.RollingFileAppender
log4j.appender.file.File=./log/project.log
log4j.appender.file.MaxFileSize=10mb
1og4j.appender.file.Threshold=DEBUG
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=[%p][%d{yyyy-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
l1og4j.logger.java.sql.PreparedStatement=DEBUG

3.设置mybatis 日志

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CsF3eGuJ-1683116135774)(C:\Users\admin\AppData\Roaming\Typora\typora-user-images\image-20230503134150279.png)]

<!--mybatis-config.xml-->
<settings>
    <setting name="logImpl" value="LOG4J"/>
</settings>
4.使用Log4j
private static Logger logger=Logger.getLogger(TestUser01Mapper.class);

//使用
@Test
public  void testLog(){
    logger.info("测试输出");
    logger.debug("测试输出");
    logger.error("测试输出");
}

七、分页(limit)

使用sql的limit关键字来实现分页

//分页接口
List<User> getUserLimit(Map<String,Integer> map);
<!-- 分页sql实现 -->
<!--    分页查询 第一个参数表示从那个索引开始,第二个参数表示一页展示多少条-->
<select id="getUserLimit" resultType="com.suzezhi.pojo.User">
    select * from user limit #{startIndex},#{pageSize};
</select>
//测试
//分页查询
@Test
public void getUserByLimit(){
    SqlSession sqlSession = MybatisUtil.getSqlSession();
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    Map<String, Integer> map = new HashMap<String, Integer>();
    //两个键要与上面sql的参数一致
    map.put("startIndex",0);
    map.put("pageSize",2);
    List<User> userLimit = mapper.getUserLimit(map);
    for (User user : userLimit) {
        System.out.println(user);
    }
}

alue=“LOG4J”/>


#### 4.使用Log4j

```java
private static Logger logger=Logger.getLogger(TestUser01Mapper.class);

//使用
@Test
public  void testLog(){
    logger.info("测试输出");
    logger.debug("测试输出");
    logger.error("测试输出");
}

七、分页(limit)

使用sql的limit关键字来实现分页

//分页接口
List<User> getUserLimit(Map<String,Integer> map);
<!-- 分页sql实现 -->
<!--    分页查询 第一个参数表示从那个索引开始,第二个参数表示一页展示多少条-->
<select id="getUserLimit" resultType="com.suzezhi.pojo.User">
    select * from user limit #{startIndex},#{pageSize};
</select>
//测试
//分页查询
@Test
public void getUserByLimit(){
    SqlSession sqlSession = MybatisUtil.getSqlSession();
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    Map<String, Integer> map = new HashMap<String, Integer>();
    //两个键要与上面sql的参数一致
    map.put("startIndex",0);
    map.put("pageSize",2);
    List<User> userLimit = mapper.getUserLimit(map);
    for (User user : userLimit) {
        System.out.println(user);
    }
}
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值