Mybatis学习笔记--延迟加载与缓存(1),2024年最新java银行面试题目及答案

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

List accounts=accountDao.findAll();

for (Account account : accounts){

System.out.println(“每个account信息”);

System.out.println(account);

System.out.println(account.getUser());

}

}

测试结果:

在这里插入图片描述

一对多延迟加载:

以之前的用户账户案例为例:在IAccountDao接口中添加List<Account> findAccountByUid(Integer uid);方法,以及修改IUserDao.xml配置文件中的相关映射配置:

<?xml version="1.0" encoding="UTF-8"?>

select * from user

select * from user where id=#{id}

代码测试:

/**

  • 测试查询所有

*/

@Test

public void testFindAll(){

//5.使用代理对象执行方法

List users=userDao.findAll();

for (User user : users){

System.out.println(“-----------每个用户的信息----------”);

System.out.println(user);

System.out.println(user.getAccounts());

}

}

测试结果:

在这里插入图片描述

Mybatis中的缓存


缓存:存在于内存中的临时数据

为了减少和数据库的交互次数,提高执行效率引入了缓存机制,当一些数据满足:经常查询、不经常改变、并且其正确与否对最终结果影响不大等特点时,可以对数据进行缓存以提高效率。而当数据经常改变,并且对数据的准确性要求很高时,不适合使用缓存。

前期准备

项目结构:

在这里插入图片描述

User类:

public class User implements Serializable {

private Integer id;

private String username;

private String address;

private String sex;

private Date birthday;

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getUsername() {

return username;

}

public void setUsername(String username) {

this.username = username;

}

public String getAddress() {

return address;

}

public void setAddress(String address) {

this.address = address;

}

public String getSex() {

return sex;

}

public void setSex(String sex) {

this.sex = sex;

}

public Date getBirthday() {

return birthday;

}

public void setBirthday(Date birthday) {

this.birthday = birthday;

}

}

IUserDao接口:

public interface IUserDao{

/**

  • 查询所有用户

  • @return

*/

List findAll();

/**

  • 根据id查询一个用户id

  • @param userId

*/

User findById(Integer userId);

/**

  • 更新用户信息

  • @param user

*/

void updateUser(User user);

}

IUserDao.xml配置文件:

<?xml version="1.0" encoding="UTF-8"?>

select * from user

select * from user where id=#{id}

update user set username=#{username},address=#{address} where id=#{id}

Mybatis中的一级缓存和二级缓存

一级缓存:指的是mybatis中SqlSession对象的缓存。当我们执行查询之后,查询的结果会同时存在到SqlSession为我们提供的一块区域中。该区域的结构就是一个Map。当我们再次查询同样的数据,mybatis会先去sqlsession中查询是否有,有的话直接拿出来用。当SqlSession对象消失时,mybatis的一级缓存就会消失。

测试代码:

public class UserTest {

private InputStream in;

private SqlSessionFactory factory;

private SqlSession sqlSession;

private IUserDao userDao;

@Before//再测试方法执行之前执行

public void init() throws Exception{

//1.读取配置文件,生成字节输入流

in= Resources.getResourceAsStream(“SqlMapConfig.xml”);

//2.创建SqlSessionFactory工厂,获取SqlSessionFactory对象

factory=new SqlSessionFactoryBuilder().build(in);

//3.使用工厂生产SqlSession对象

sqlSession=factory.openSession();

//4.使用SqlSession创建Dao接口的代理对象

userDao=sqlSession.getMapper(IUserDao.class);

}

@After//用于在测试方法执行之后执行

public void destroy() throws Exception{

//提交事务

sqlSession.commit();

//6.释放资源

sqlSession.close();

in.close();

}

/**

  • 测试一级缓存

*/

@Test

public void testFirstLevelCache(){

//5.使用代理对象执行方法

User user1=userDao.findById(1);

System.out.println(user1);

/*

通过测试我们会发现两个对象是同一个,返回的值是true,并且只进行了一次查询,第二次是从缓存中取,而当我们关闭sqlSession后再次创建时,会发现两个对象已经不一样了。

sqlSession.close();

//再次开启SqlSession对象

sqlSession =factory.openSession();

userDao =sqlSession.getMapper(IUserDao.class);

//sqlSession.clearCache(); //和上面三行代码效果一样,可以清空缓存

*/

User user2=userDao.findById(1);

System.out.println(user2);

System.out.println(user1==user2);

}

/**

  • 测试缓存的同步

*/

@Test

public void testClearCache(){

//5.使用代理对象执行方法

//根据id查询用户

User user1=userDao.findById(1);

System.out.println(user1);

//更新用户

user1.setUsername(“update”);

user1.setAddress(“北京”);

userDao.updateUser(user1);

User user2=userDao.findById(1);

System.out.println(user2);

/*

*一级缓存时SqlSession范围的缓存,当调用SqlSession的修改、添加、删除、commit()、close()等方法时会清空缓存。

*从测试结果中我们可以看出,对象已经改变,在使用user2进行查询时,又执行了一次查询语句

*/

System.out.println(user1==user2);

}

}

运行结果:

在这里插入图片描述

二级缓存:它指的是Mybatis中SqlSessionFactory对象的缓存。由同一个SqlSessionFactory对象创建的SqlSession共享其缓存。

在这里插入图片描述

二级缓存的使用步骤:

第一步:让Mybatis框架支持二级缓存(在SqlMapConfig.xml中配置)

第二步:让当前的映射文件支持二级缓存(在IUserDao.xml中配置)

第三步:让当前的操作支持二级缓存(在select标签中配置)

配置SqlMapConfig.xml: 在SqlMapConfig.xml的中添加配置

配置IUserDao.xml:

总结

对于面试,一定要有良好的心态,这位小伙伴面试美团的时候没有被前面阿里的面试影响到,发挥也很正常,也就能顺利拿下美团的offer。
小编还整理了大厂java程序员面试涉及到的绝大部分面试题及答案,希望能帮助到大家,

在这里插入图片描述

在这里插入图片描述

最后感谢大家的支持,希望小编整理的资料能够帮助到大家!也祝愿大家都能够升职加薪!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
tting name=“cacheEnabled” value=“true”/>

配置IUserDao.xml:

总结

对于面试,一定要有良好的心态,这位小伙伴面试美团的时候没有被前面阿里的面试影响到,发挥也很正常,也就能顺利拿下美团的offer。
小编还整理了大厂java程序员面试涉及到的绝大部分面试题及答案,希望能帮助到大家,

[外链图片转存中…(img-nzUOw5PP-1713564605799)]

[外链图片转存中…(img-q0UocxqE-1713564605799)]

最后感谢大家的支持,希望小编整理的资料能够帮助到大家!也祝愿大家都能够升职加薪!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-beoNhZ2F-1713564605799)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 21
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值