2 持久化和持久层
持久化
-
将原本存储在内存的临时数据保存到可永久化的存储设备中。
-
JDBC就是一种持久化机制。文件IO也是一种持久化机制。
-
持久化的需要是因为内存的缺陷引起的
持久层
- 完成持久化工作的代码块 . ----> dao层 【DAO (Data Access Object) 数据访问对象】
3 Mybatis的优点
-
使sql与程序代码解耦合
-
灵活,不会对应用程序产生影响
mybatis快速构建
===========
为了方便使用可以安装lombox插件和Free Mybatis plugn插件
流程:pom环境–>mybatis-configxml配置文件–>工具类–>实体类–>接口–>接口实现类–>测试类
1.pom.xml
2.mybatis-config.xml
3.SqlSessionUtil工具类(用于获取session)
4.实体类UserInf
5.接口UserMapper
6.List selectUser();
接口实现UserMapper.xml
别忘了在Mybatis-config.xml中注册
7.测试
mybatis的增删改查
============
session.commit(); //提交事务,重点!不写的话不会提交到数据库
1 namespace说明
namespace命名空间作为在mapper中的属性之一,是Mapper接口与xml实现的唯一依据。
2 select
UserMapper接口增加方法
//根据id查询用户
UserInf selectUserById(@Param(“id”)int id);
UserMapper.xml增加方法对应映射
测试
3 insert
UserMapper接口增加方法
//增加用户信息
int addUserInf(UserInf userInf);
UserMapper.xml增加方法对应映射
测试
4 update
UserMapper接口增加方法
//修改用户信息
int updateUserInf(UserInf userInf);
UserMapper.xml增加方法对应映射
测试
5 delete
UserMapper接口增加方法
//根据id删除用户
int deleteUser(@Param(“id”)int id);
UserMapper.xml增加方法对应映射
测试
6 模糊查询
第1种:在Java代码中添加sql通配符。
第2种:在sql语句中拼接通配符,会引起sql注入
7 注意点
所有的增删改操作都需要提交事务!
接口所有的普通参数,尽量都写上@Param参数,尤其是多个参数时,必须写上!
有时候根据业务的需求,可以考虑使用map传递参数!
为了规范操作,在SQL的配置文件中,我们尽量将Parameter参数和resultType都写上!
mybatis配置详解
===========
1 核心配置文件
-
mybatis-confifig.xml 系统核心配置文件
-
MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息
-
一些属性和配置内容说明:
configuration(配置)
properties(属性)
settings(设置)
typeAliases(类型别名)
typeHandlers(类型处理器)
objectFactory(对象工厂)
plugins(插件)
environments(环境配置)
environment(环境变量)
transactionManager(事务管理器)
dataSource(数据源)
databaseIdProvider(数据库厂商标识)
mappers(映射器)
2 environments(环境配置)
根据生产上的要求,不同部门可能需要不同环境,可以配置多套环境,但是只能同时使用一个,且必须指定其中一个为默认运行环境(通过default指定)
子元素节点:environment
具体的一套环境,通过设置id进行区别,id保证唯一!
- 子元素节点:transactionManager - [ 事务管理器 ]
MyBatis 中有两种类型的事务管理器(也就是 type=“[JDBC|MANAGED]”)在单独的mybatis中不需要进行额外配置
- 子元素节点:dataSource(数据源)
dataSource 元素使用标准的 JDBC 数据源接口来配置 JDBC 连接对象的资源。
有三种内建的数据源类型(type=“[UNPOOLED|POOLED|JNDI]"))
3 mappers(映射器)
映射器 : 定义映射SQL语句文件
3.1 引入资源的不同方式
3.2 Mapper文件模板
4 properties(属性)
-
properties 属性可以利用配置文件或者java代码来动态更改
-
在多处中配置了属性时,propertie中的值会被resouce中的覆盖,会被java代码中的方法传参覆盖。
-
可以采用占位符的形式来配置属性默认值官方文档
4.1使用配置文件优化
新建config.properties
导入配置文件并占位符显示属性值
5 typeAliases(别名)
为解决包名过长问题的代码冗余。
第一种方式
在所有使用com.lyj.entity.UserInf的地方都可以用User代替
第二种方式
在com.lyj.entity包下的所有实体类都可以使用类名首字母小写的方式引用(如com.lyj.entity.UserInf用userInf代替)
也可以在实体类加上注解的方式自定义别名
@Alias(“user”)
public class UserInf { … }
6 settings(设置)
可以为mybatis增加设置
数据库驼峰名转换设置
log日志设置显示
ResultMap(结果集映射)
================
为了解决数据映射问题而生
1 解决数据库与实体类属性名不一致问题
解决的问题:属性名和字段名不一致
因为各种原因,数据库的属性字段无法和实体类的属性字段一一对应。
举例:
现在数据库表属性为:
实体类属性值为:
查询语句:
这样查询,因为pwd在实体类中并不存在,在注入值时无法注入。出现password属性为空的情况。
解决方案
使用别名(可简写 pwd password)
使用结果集映射->ResultMap 【推荐】
2 解决多对一结果集映射(association关联属性)
多对一理解:
-
多个学生对应一个老师。
-
数据库概念理解:学生拥有一个tid与教师id对应。
-
实体类概念理解:学生拥有一个教师对象。
2.1 按查询嵌套处理
实体类student和teacher
StudentMapper增加接口
//查询所有学生
public List queryAllStudents();
StudentMapper.xml增加对应方法(对于对象属性teacher采用关联属性)
测试(对于对象属性teacher的属性采用关联属性)
2.2 按结果嵌套处理。
3解决一对多结果集映射(collection集合)
一对多理解:
-
一个老师有多个学生
-
数据库概念理解:教师拥有一个id与学生tid对应。
-
实体类概念理解:教师拥有一个学生对象List集合。
3.1 按查询嵌套处理。
实体类Student和Teacher
TeacherMapper增加方法
public Teacher getTeacher(int id);
TeacherMapper.xml增加实现
测试
3.2 按结果嵌套处理
动态SQL
=====
动态SQL指的是根据不同的查询条件 , 生成不同的Sql语句。
1 环境
utils工具类:随机生成id
entity实体类
其他正常布置,数据库添加数据。
2 if语句
需求:根据作者名字和博客名字来查询博客!如果作者名字为空,那么只根据博客名字查询,反之,则根据作者名来查询
xml文件实现
注意:在依次执行所有的if语句,因此当title为空,author不为空时,产生错误。引入where
3 where语句
xml文件实现
注意:当where包含的标签有返回值时能够自动加上where字符,同时当检测标签开头含有 AND或 OR 字符时,会将字符除去。
4 choose语句
利用if 和where搭配已经能够解决大部分的SQL查询拼接,但是有时候我们需要某一个条件不为空时立即跳出不在接受参数。这个时候我们可以利用choose实现,相当于编程语言中的 switch。
xml实现:
读起来十分有switch-case-otherwise的既视感。
5 foreach语句
foreach 相当于for循环,当我们需要一次性查询多个内容时,可以用foreach来实现这一功能。
测试:
相当于SQL语句:select * from blog where (id=1 or id=2 or id=3)
6 set语句
当我们需要进行修改操作时,set的操作配合if使用会现之前查询出现的问题。
不用set标签之前,当author为空时,名=SQL语句拼接就会出错,这个时候使用set标签可以很好的解决这个问题。
使用set标签后
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
6 set语句*
当我们需要进行修改操作时,set的操作配合if使用会现之前查询出现的问题。
不用set标签之前,当author为空时,名=SQL语句拼接就会出错,这个时候使用set标签可以很好的解决这个问题。
使用set标签后
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-DpZ86jib-1715664383779)]
[外链图片转存中…(img-wpI1I4dq-1715664383780)]
[外链图片转存中…(img-CYi9juLU-1715664383780)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!