mybatis框架搭建、mybatis打印日志设置、参数传递使用、myatis插件MyBatisX

一、框架

就是对技术的封装,将基础的技术进行封装,让程序员可以快速的使用,提高效率。

Java后端框架:

mybatis:对jdbc进行封装 

spring:对整个Java后端架构进行管理的

springweb:对web层(servlet)进行封装

springboot:对spring框架的搭建进行封装

二、mybatis背景

mybatis原来是apache下面的一个开源项目,名为ibatis,2010年开发团队转移到谷歌旗下,改名为mybatis。

mybatis介绍:mybatis是一个优秀的数据持久层框架(dao层  数据访问层  数据持久层)

是一个对jdbc进行的封装,避免了jdbc手动设置参数,手动映射结果的操作

mybatis将jdbc中的接口进行封装,提供了它自己的类和接口实现

可以使用xml配置和注解的方式,将数据库中记录自动映射到Java对象中,是一种ORM实现(对象关系映射)将可以自动将数据映射到对象中的这种框架,也称为ORM框架

mybatis还提供了动态sql和数据缓存

三、mybatis搭建

1、创建一个maven项目

2、导入mybatis依赖的jar包,在pom。xml中进行配置

        <!--mybatis-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.2</version>
        </dependency>

3、创建一个全局的mybatis配置文件,配置数据库连接等配置

在rescources下创建一个普通文件(mybatis.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">

<!--mybatis核心全局配置文件-->
<configuration>
<settings>
    <!--配置日志-->
    <setting name="logImpl" value="STDOUT_LOGGING"/>
    <!--开启驼峰命名自动映射-->
    <setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>
    <!--为类配置别名-->
    <typeAliases>
       <!-- <typeAlias type="com.ffyc.mybatispro.model.Admin" alias="Admin"></typeAlias>-->
        <package name="com.ffyc.mybatispro.model"/>
    </typeAliases>
       <!--配置数据库连接相关信息-->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <!--type="POOLED" 使用数据库连接池功能 ,默认创建了10个链接对象,减少频繁创建链接对象-->
            <dataSource type="POOLED">
                <!--数据库连接配置-->
                <property name="driver" value="com.mysql.cj.jdbc.Driver" />
                <property name="url" value="jdbc:mysql://127.0.0.1:3306/ssmdb?serverTimezone=Asia/Shanghai" />
                <property name="username" value="root" />
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>
    
    <!--注册映射文件-->
    <mappers>
        <mapper resource="mappers/AdminMappers.xml"></mapper>
    </mappers>
    
</configuration>

数据库连接池

连接数据库,每次访问数据库的时候,创建一个Connection用完关闭

但是访问量大了之后,每次都要创建新的连接对象,用完关闭,比较耗时

使用数据库连接池,在池(集合)中先创建一些连接对象,用户访问时,就直接池中获取一个链接对象,用完不销毁,还会池中,这样就减少频繁创建销毁对象

使用数据库连接池功能,默认创建了10个对现象,减少频繁创建连接对象

4、创建数据库创建表,创建数据

5、创建一个访问的接口

6、创建sql映射文件

在rescources下创建一个包(Mappers),包下创建一个普通文件(AdminMappers.xml)文件名可以自己进行修改

7、测试mybatis

1、读取mybatis配置文件 

 Reader reader= Resources.getResourceAsReader("mybatis.xml");
//"mybatis.xml"是对mybatis的配置文件名

2、创建 SqlSessionFactory

//2.创建SqlSessionFactory
SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);

3、创建 SqlSession

//3.创建 SqlSession
SqlSession sqlSession=sqlSessionFactory.openSession();

4、获得接口代理对象

//4创建接口代理对象
AdminDao adminDao =  sqlSession.getMapper(AdminDao.class);

sql映射文件和接口对应关系

四、 mybatis日志

配置日志

<settings>
    <setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>

 

在配置时,按照规定的顺序进行配置 

五、 参数传递

单值传递

 /*一个值传参数*/
    Admin findAdminByid(int id);
    void deleteAdmin(int id);
    Admin findAdminByAccount(String account);

 相对于的映射文件中的配置

  <select id="findAdminByid" parameterType="int" resultType="Admin">
                select * from admin where id =#{id}
</select>

  <delete id="deleteAdmin" parameterType="int">
        delete from admin where id = #{id}
    </delete>
   <select id="findAdminByAccount" parameterType="string" resultType="Admin">
         select * from admin where account =#{account}
    </select>

多值传递

使用@Param进行值的绑定

 /*多个值传参数*/
    Admin login(@Param("acc") String account,@Param("pwd") String password);

相对于的映射文件中的配置

 <select id="login" resultType="Admin">
        select * from admin where account=#{acc} and password=#{pwd}
         </select>

也可以是对象传参

 /*对象传参数*/
    Admin login1(Admin admin);

 相对于的映射文件中的配置

<select id="login1" parameterType="admin" resultType="Admin">
        select * from admin where account=#{account} and password=#{password}
         </select>

 这里account和password是Admin中的属性

六、mybatis使用示例(新增、修改、删除)

数据库事务:是数据库的一种管理机制,是对一次连接数据库过程的管理操作,保证一次操作中,执行的多条sql,要么都成功执行,要么都不执行。

因此,在Java中执行新增,修改,删除操作时都要进行手动提交事务(

sqlSession.commit();//提交数据库事务,当我们的程序代码块没有任何问题时,在向数据库提交事务操作,数据库才会执行sql,出现异常不提交事务

新增示例:(单表操作)

1、定义新增接口

package com.ffyc.mybatispro.dao;
import com.ffyc.mybatispro.model.Admin;
import java.util.List;
public interface AdminDao {
    /*对象传参数*/
    void insertAdmin(Admin admin);
}

2、在sql映射文件中写sql语句

    <insert id="insertAdmin" parameterType="Admin" useGeneratedKeys="true" keyProperty="id" keyColumn="id">
        insert into admin(account,password,gender) values(#{account},#{password},#{gender})
    </insert>
useGeneratedKeys="true":返回自增主键
keyProperty="id":第一接收属性
 keyColumn="id":数据库列

单表查询,返回的结果mybatis可以自动将一条记录映射到Java对象中
要求:列名和对象属性一致

3、单元测试(程序员使用的测试方法,以方法为单位)

所以需要引入junit依赖

          <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>provided</scope>
          </dependency>
 @Test
    public void insert(){
  //1.mybatis读取配置文件
      Reader reader= Resources.getResourceAsReader("mybatis.xml");
        //2.创建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);
        //SqlSessionFactory对象也只需要创建一次,创建后不想需要销毁
        //3.创建 SqlSession
        SqlSession sqlSession=sqlSessionFactory.openSession();//打开与数据库的会话
        System.out.println("新增");
        Admin admin=new Admin();
        admin.setAccount("aaa");
        admin.setPassword("123");
        admin.setGender("男");
        AdminDao adminDao=sqlSession.getMapper(AdminDao.class);
        adminDao.insertAdmin(admin);//保存数据后,需要立刻拿到这条数据在数据库中的主键
        System.out.println(admin.getId());

        sqlSession.commit();//手动提交数据库事务管理
        sqlSession.close();
       
    }

 2、修改示例

1、定义修改接口

package com.ffyc.mybatispro.dao;

import com.ffyc.mybatispro.model.Admin;
import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface AdminDao {

    /*对象传参数*/
    void updateAdmin(Admin admin);

}

2、在sql映射文件中写sql语句

   <update id="updateAdmin" parameterType="Admin">
        update admin set account=#{account},password=#{password} where id=#{id}
    </update>

3、单元测试

    public void update(){

        System.out.println("修改");
      Reader reader= Resources.getResourceAsReader("mybatis.xml");
        //2.创建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);
        //SqlSessionFactory对象也只需要创建一次,创建后不想需要销毁
        //3.创建 SqlSession
        SqlSession sqlSession=sqlSessionFactory.openSession();//打开与数据库的会话
        
        AdminDao adminDao=sqlSession.getMapper(AdminDao.class);
        Admin admin=new Admin();
        admin.setId(3);
        admin.setAccount("ccc");
        admin.setPassword("666");
        admin.setGender("男");
        adminDao.updateAdmin(admin);
        sqlSession.commit();
        sqlSession.close();
    }

执行结果

 

删除示例

1、定义删除接口

package com.ffyc.mybatispro.dao;

import com.ffyc.mybatispro.model.Admin;
import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface AdminDao {

    /*一个值传参数*/

    void deleteAdmin(int id);
   
 

}

2、在sql映射文件中写sql语句

    <delete id="deleteAdmin" parameterType="int">
        delete from admin where id = #{id}
    </delete>

3、单元测试

   @Test
    public void delete(){
        System.out.println("删除");
       PUblic static void main(String[] args) throws IOException {
        //1.mybatis读取配置文件
      Reader reader= Resources.getResourceAsReader("mybatis.xml");
        //2.创建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);
        //SqlSessionFactory对象也只需要创建一次,创建后不想需要销毁
        //3.创建 SqlSession
        SqlSession sqlSession=sqlSessionFactory.openSession();//打开与数据库的会话
        
        AdminDao adminDao=sqlSession.getMapper(AdminDao.class);
        adminDao.deleteAdmin(3);
        sqlSession.commit();
        sqlSession.close();
    }

执行结果

删除了id=3的一行

七、🐦🐦🐦MybatisX:

 mybatis的一个小插件可以快速帮助我们使用sql映射文件和接口

点击旁边的小鸟会快速的转换到相应的sql映射文件或者时接口

### MyBatis打印日志的原因及解决方案 #### 原因分析 MyBatis未正常打印SQL日志可能由以下几个原因引起: 1. **日志级别错误**:如果`logger`的日志级别不是`DEBUG`,即使进行了相关配置,MyBatis也无法打印SQL日志[^1]。 2. **版本差异**:不同版本的MyBatis日志框架的支持和配置方式有所不同。例如,MyBatis 3.0.6、3.1.0 和 3.2.0 及更高版本之间的日志配置方法存在显著区别。 3. **日志框架冲突**:当项目中同时存在多个日志框架(如SLF4J、Commons Logging等),而没有正确配置桥接器时,可能导致日志无法正常输出。 4. **配置文件缺失或错误**:在Spring Boot项目中,若`application.yml`中的日志配置有误,则会影响SQL日志打印效果[^2][^3]。 --- #### 解决方案 以下是针对MyBatis打印日志问题的具体解决办法: ##### 方法一:调整日志级别至`DEBUG` 确保MyBatis对应的`logger`被设置为`DEBUG`级别。可以通过以下方式进行配置: - 如果使用Log4j作为日志框架,可以在`log4j.properties`中添加如下内容: ```properties log4j.logger.org.mybatis=DEBUG log4j.logger.java.sql=DEBUG ``` - 对于Spring Boot项目,可在`application.yml`中指定日志级别: ```yaml logging: level: org.mybatis: DEBUG java.sql: DEBUG ``` 此操作可确保MyBatis及其内部组件能够记录详细的SQL执行信息^。 ##### 方法二:显式指定日志实现 通过`mybatis.configuration.log-impl`参数强制指定日志实现类。例如,在`application.yml`中加入以下配置: ```yaml mybatis: configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl ``` 该配置会将SQL日志直接输出到控制台,适用于快速排查问题场景[^2]^。 ##### 方法三:结合具体日志框架进行配置 根据不同项目的实际需求选择适合的日志框架并完成相应配置: - 使用Log4j2时,可以这样配置: ```yaml mybatis: configuration: log-impl: org.apache.ibatis.logging.log4j2.Log4j2Impl ``` - 若采用自定义日志逻辑,也可以在启动类中手动调用`LogFactory.useCustomLogging()`方法: ```java import org.apache.ibatis.logging.LogFactory; public class Application { static { LogFactory.useCustomLogging(StdOutImpl.class); } } ``` 这种方法特别适合那些已经集成了特定日志系统的复杂工程环境[^4]^。 ##### 方法四:处理多日志框架共存的情况 当项目依赖了多种日志库时,需引入适当的桥接Jar包以消除潜在冲突。比如,对于SLF4J与Log4j组合的情形,应包含`slf4j-log4j12.jar`;而对于Logback则需要`slf4j-logback-classic.jar`等[^1]^。 --- ### 总结 综上所述,要成功使MyBatis打印SQL日志,不仅要注意基础配置是否恰当,还需兼顾所选日志框架特性以及项目整体结构特点做出针对性修改。只有做到精确匹配各要素间关系,才能从根本上杜绝此类异常现象的发生。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冯宇星的技术博客笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值