• 2025-01-06《深入理解Mybatis原理》MyBatis的sqlSession执行流程
    sqlSessionFactory与SqlSession正如其名,Sqlsession对应着一次数据库会话。由于数据库会话不是永久的,因此Sqlsession的生命周期也不应该是永久的,相反,在你每次访问数据库时都需要创建它(当然并不是说在Sqlsession里只能执行一次sql,你可以执行多次,当一旦关闭了Sqlsession就需要重新
  • 2025-01-02MyBatis的缓存
    Mybatis的一级缓存一级缓存是sqlSession级别的,通过同一个SqlSession查询的数据会被缓存,下次查询相同的数据,就会从缓存中直接获取,不会从数据库重新访问使一级缓存失效的四种情况:不同的SqlSession对应不同的一级缓存同一个SqlSession但是查询条件不同同一个SqlSession两次查询
  • 2025-01-01DefaultSqlSession 和 SqlSessionTemplate 的线程安全问题
    总结自:DefaultSqlSession和SqlSessionTemplate的线程安全问题、MyBatis与Spring整合时是如何解决SqlSession线程不安全的问题的DefaultSqlSession原因1:Connection本身是线程不安全的。如果多个线程获取到同一个Connection进行数据库操作,一个线程正在更新数据,而另
  • 2024-12-31由 Mybatis 源码畅谈软件设计(七):从根上理解 Mybatis 一级缓存
    作者:京东保险王奕龙本篇我们来讲一级缓存,重点关注它的实现原理:何时生效、生效范围和何时失效,在未来设计缓存使用时,提供一些借鉴和参考。1.准备工作定义实体publicclassDepartment{publicDepartment(Stringid){this.id=id;}privateStri
  • 2024-12-29【MyBatis 核心工作机制】注解式开发与动态代理原理
    有很多朋友可能已经在开发中熟练使用MyBatis 或者刚开始学习MyBatis,对于它的一些工作机制不太了解。“咦,怎么写几个注解,写几个配置文件,就能实现这些效果呢,好神奇呀!”当你看完这篇博客之后,你会不经赞叹MyBatis框架设计者的巧妙,并且会帮助你理解这个工作机制。还是先大
  • 2024-12-269.20
    mybatis的应用能大大简化我们编写程序的代码并提升效率。packagecom.aurora.mybatis.test;importcom.aurora.mybatis.mapper.ParameterMapper;importcom.aurora.mybatis.pojo.User;importcom.aurora.mybatis.utils.SqlSessionUtils;importorg.apache.ibatis.session.
  • 2024-12-24mybatis
    1.什么是mybatis框架?MyBatis是一款优秀的持久层框架,它支持自定义SQL、存储过程以及高级映射。MyBatis免除了几乎所有的JDBC代码以及设置参数和获取结果集的工作。MyBatis可以通过简单的XML或注解来配置和映射实体类型、接口和JavaPOJO(PlainOldJavaObjects,普通老式
  • 2024-12-20深入剖析MyBatis的架构原理与核心机制
    目录引言MyBatis概述MyBatis的整体架构设计MyBatis核心组件解析1.SqlSessionFactory与SqlSession2.Configuration对象3.MappedStatement与SqlSource4.Executor执行器5.缓存机制MyBatis的执行流程解析动态SQL的实现原理MyBatis插件机制MyBatis与Spring的整合总结引
  • 2024-12-19java_Web 实战06
    java_Web实战06在实现功能的同时要做前端的jsp和后端的servlet方面的处理,同时这里使用scv三层架构,所以要书写secvice层和dao层数据库的mapper的代码,在书写mapper时要配置xml文件<!DOCTYPEconfigurationPUBLIC"-//mybatis.org//DTDConfig3.0//EN""htt
  • 2024-12-19优化 MyBatis SqlSession 工具类:提升代码健壮性与可维护性
    优化MyBatisSqlSession工具类:提升代码健壮性与可维护性引言在Java开发中,MyBatis是一个广泛使用的持久层框架,而SqlSession是MyBatis的核心对象之一。为了简化SqlSession的管理,我们通常会编写一个工具类来封装其创建、提交、回滚和关闭等操作。本文将基于一个常见的
  • 2024-12-15【mybatis】缓存
    目录1.mybatis的运行1.1引言1.2具体运行: 1.3sqlSession介绍localcatch2.缓存2.1概念 2.2使用缓存的原因2.3 什么样的数据能使用缓存3.  Mybatis缓存 3.1一级缓存3.1.1 测试一级缓存3.1.2  缓存失效的四种情况$1 sqlSession不同$2  sqlSes
  • 2024-12-13SqlSessionTemplate
    SqlSessionTemplate是MyBatis提供的一个非常重要的类,通常在Spring与MyBatis集成时使用。它用于简化MyBatis的SqlSession操作,并提供了线程安全的封装,以便在Spring的环境中高效地执行数据库操作。基本概念SqlSession:SqlSession是MyBatis提供的核心接口,用于执
  • 2024-12-11MyBatis SqlSession 工具类详解与最佳实践
    MyBatisSqlSession工具类详解与最佳实践博客简介在Java应用开发中,MyBatis是一个非常流行的持久层框架,它简化了数据库操作。为了更好地管理SqlSession的创建和关闭,通常会编写一个工具类来封装这些功能。本文将详细介绍一个优化后的SqlSessionUtils工具类,并解释其设计原
  • 2024-12-11Maven、mybatis框架
    一、Maven介绍1.概念:Maven项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的项目管理工具软件。2.为啥使用maven:之前项目中需要引入大量的jar包。这些jar从网上下载,可能下载地址不同意。这些jar之间可能存在冲突。我们应该有一个软件,帮你完成jar的下
  • 2024-12-11Java框架 —— MyBatis
    MyBatis简介 持久层框架,半自动映射,支持自定义SQL、高级映射、存储过程,免除了JDBC代码、参数设置、获取结果集的工作,可以通过XML或注解方式配置、映射接口,以及实体类在数据库中的记录Hibernate和MybatisHibernate也是持久层框架,它是全自动映射,SQL编写量小,但是不够灵活,适
  • 2024-12-07工厂方法模式
    介绍工厂方法模式定义了一个用于创建对象的接口,由子类决定要实例化的类是哪一个。工厂方法让类把实例化推迟到子类。在工厂方法模式中,创建对象的工作由具体的工厂类来完成,客户端只需要知道所需产品的具体工厂,而无需关心创建细节。示例下面是一个简单的工厂方法模式的示例代码:
  • 2024-12-05MyBatis框架-缓存机制
    MyBatis是一个流行的持久层框架,它提供了强大的缓存机制来提高数据库访问性能。MyBatis的缓存机制分为一级缓存和二级缓存。下面是对这两种缓存机制的详细介绍:一级缓存(LocalCache)范围:一级缓存是SqlSession级别的缓存。也就是说,它仅在同一个SqlSession中有效。默认开
  • 2024-12-02mybatis 批量插入数据
    由于导入excel插入数据,遍历方式插入数据非常慢,所以修改成批量插入数据,代码如下:批量插入配置类@RepositorypublicclassBatchData{@AutowiredprivateSqlSessionTemplatesqlSessionTemplate;publicvoidsaveList(Stringstatement,List<?extendsObject>d
  • 2024-11-30Mybatis的二级缓存
    以根据用户id查询用户为例。二级缓存开启:1.先配置全局二级缓存,2.UserMapper.xml文件中的sql语句上开启二级缓存。两者缺一不可。首先,我们假设已经有一个MyBatis的全局配置文件mybatis-config.xml,它启用了二级缓存:<?xmlversion="1.0"encoding="UTF-8"?><!DOCTYPEconfigur
  • 2024-11-29Mybatis
    文章目录Mybatis1.介绍2.使用MyBatis的开发步骤3.MyBatis的核心对象4.系统核心配置文件(mybatis.xml)Mybatis1.介绍MyBatis前身是iBatis,本是Apache的一个开源的项目半自动化的ORM实现(ORM框架)DAO层动态SQL实体类和SQL语句之间建立映射关系持久化是程序数据
  • 2024-11-28批量操作DB
    批量操作DB记录一次批量操作数据库,sqlServer服务器参数过多问题。1.案例引入对接另一个批发系统B,B需要把订单那些数据弄到系统A中。就是一个批量插入,批量更新的问题。系统保密需要,本文只做示例,具体代码都是模拟的。(SpringBoot项目)涉及到的操作类和数据库表Order_master表
  • 2024-11-24MyBatis入门——基本的增删改查
    目录一、MyBatis简介二、搭建MyBatis(一)配置依赖(二)log4j日志功能(三)数据库配置文件——jdbc.properties(四)创建MyBatis的核心配置文件(五)使用MyBatisX插件三、项目其他配置搭建(一)创建数据库连接工具类(二)创建表(三)创建数据库的实体类(四)UserMapper接口
  • 2024-12-12第十章:风险应对措施
    在项目管理中,风险不仅仅意味着负面的威胁。风险是指不确定的事情或条件,一旦发生,会对项目目标产生影响。这种影响既可能是消极的,阻碍项目目标的实现;也可能是积极的,有助于项目目标的达成。那么风险应对措施就分为威胁应对措施和机会应对措施。1.威胁应对措施上报:将威胁上报给
  • 2024-12-09【含开题报告+文档+PPT+源码】基于SpringBoot+Vue的高校食堂外包管理系统的设计与实现
    开题报告随着高校后勤服务社会化改革的持续推进,食堂作为高校后勤服务的重要组成部分,其服务质量和管理水平直接关系到学生的日常生活质量和校园的整体形象。传统的食堂管理模式往往存在诸多问题,如菜品单一、服务质量不高、管理效率低下等,难以满足师生对餐饮服务的高品质需求。
  • 2024-12-06软工硬做——beta冲刺
    1、beta冲刺项目进展进展一项目存在的问题:个人中心模块和社区交流模块没有办法实现对用户信息的同步调用探索方案:①实现点击跳转时传递用户手机号信息,在用户登录成功后获取手机号,并在跳转时将手机号作为参数传递给目标页面。②在登录页面设置一个全局存储。解决过程:使用uni.s