Mybatis的一二级缓存,一级缓存默认开启

1.可以知道的是Mybatis的一级缓存SqlSession默认是开启的。

2.可以自己去开启二级缓存在config.xml文件中的properties下面可以加上这个配置:

  <settings>
        <!--进行懒加载-->
        <setting name="lazyLoadingEnabled" value="false"/>
        <!-- 开启缓存-->
        <setting name="cacheEnabled" value="true"/>
    </settings>

3.可以知道缓存之后的同一个session,再次执行操作的时候是不用再次查询数据库的。

resources下面建立这几个文件:
db.properties:

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/csjzjj
jdbc.username=root
jdbc.password=roothouzhicong

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>

    <properties resource="db.properties"></properties>
	<environments default="development">
		<environment id="development">
		<transactionManager type="jdbc"></transactionManager>
		<dataSource type="POOLED">
		 <property name="driver" value="${jdbc.driver}"/>
         <property name="url" value="${jdbc.url}"/>
         <property name="username" value="${jdbc.username}"/>
         <property name="password" value="${jdbc.password}"/>
		</dataSource>
		</environment>
	</environments>
	
	<mappers>
     <!--要使用注解方式-->
      <mapper class="com.zjj.mapper.MyUserMapper"></mapper>
	</mappers>

</configuration>

MyUserMapper:

package com.zjj.mapper;

import com.zjj.entity.MyUser;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * @Program mybatis
 * @Package com.zjj.mapper
 * @Auther TeacherHuang
 * @Date 2021/8/16 15:29
 * @Version 1.0
 */
public interface MyUserMapper {

    @Select("select *from myuser")
    List<MyUser> selectAll() throws  Exception;

    @Select("select *from myuser")
    List<MyUser> selectAll01() throws  Exception;
}

Test:

import com.zjj.entity.MyUser;
import com.zjj.mapper.MyUserMapper;
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;
import java.util.List;

/**
 * @Program mybatis
 * @Package PACKAGE_NAME
 * @Auther TeacherHuang
 * @Date 2021/8/16 15:31
 * @Version 1.0
 */
public class Test {
    public static void main(String[] args) throws Exception {
        String resources="config.xml";
        InputStream inputstream = Resources.getResourceAsStream(resources);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputstream);
        SqlSession session = sqlSessionFactory.openSession(true);
        System.out.println(session);



       MyUserMapper myUserMapper = session.getMapper(MyUserMapper.class);
         System.out.println("第一次没有缓存数据的时候---------------------");
        List<MyUser> myUsers = myUserMapper.selectAll();
        System.out.println(myUsers);

//        session.close();
          session.clearCache();

        System.out.println("第二次没有缓存数据的时候---------------------");
        MyUserMapper myUserMapper02 = session.getMapper(MyUserMapper.class);
        List<MyUser> myUsers01 = myUserMapper.selectAll();
        System.out.println(myUsers01);




    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

有时间指导毕业设计

觉得写的好的话可以给我打赏

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

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

打赏作者

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

抵扣说明:

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

余额充值