5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

mybatis简介

=========

1 mybatis是什么

  • MyBatis 是一款优秀的持久层框架

  • MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的过程

  • MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 实体类 【Plain Old Java Objects,普通的 Java对象】映射成数据库中的记录。

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

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)

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

4.实体类UserInf

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

5.接口UserMapper

6.List selectUser();

接口实现UserMapper.xml

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

别忘了在Mybatis-config.xml中注册

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

7.测试

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

mybatis的增删改查

============

session.commit(); //提交事务,重点!不写的话不会提交到数据库

1 namespace说明

namespace命名空间作为在mapper中的属性之一,是Mapper接口与xml实现的唯一依据。

2 select

UserMapper接口增加方法

//根据id查询用户

UserInf selectUserById(@Param(“id”)int id);

UserMapper.xml增加方法对应映射

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

测试

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

3 insert

UserMapper接口增加方法

//增加用户信息

int addUserInf(UserInf userInf);

UserMapper.xml增加方法对应映射

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

测试

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

4 update

UserMapper接口增加方法

//修改用户信息

int updateUserInf(UserInf userInf);

UserMapper.xml增加方法对应映射

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

测试

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

5 delete

UserMapper接口增加方法

//根据id删除用户

int deleteUser(@Param(“id”)int id);

UserMapper.xml增加方法对应映射

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

测试

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

6 模糊查询

第1种:在Java代码中添加sql通配符。

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

第2种:在sql语句中拼接通配符,会引起sql注入

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

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(环境配置)

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

根据生产上的要求,不同部门可能需要不同环境,可以配置多套环境,但是只能同时使用一个,且必须指定其中一个为默认运行环境(通过default指定)

子元素节点:environment

具体的一套环境,通过设置id进行区别,id保证唯一!

  • 子元素节点:transactionManager - [ 事务管理器 ]

MyBatis 中有两种类型的事务管理器(也就是 type=“[JDBC|MANAGED]”)在单独的mybatis中不需要进行额外配置

  • 子元素节点:dataSource(数据源)

dataSource 元素使用标准的 JDBC 数据源接口来配置 JDBC 连接对象的资源。

有三种内建的数据源类型(type=“[UNPOOLED|POOLED|JNDI]"))

3 mappers(映射器)

映射器 : 定义映射SQL语句文件

3.1 引入资源的不同方式

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

3.2 Mapper文件模板

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

4 properties(属性)

  • properties 属性可以利用配置文件或者java代码来动态更改

  • 在多处中配置了属性时,propertie中的值会被resouce中的覆盖,会被java代码中的方法传参覆盖。

  • 可以采用占位符的形式来配置属性默认值官方文档

4.1使用配置文件优化

新建config.properties

导入配置文件并占位符显示属性值

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

5 typeAliases(别名)

为解决包名过长问题的代码冗余。

第一种方式

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

在所有使用com.lyj.entity.UserInf的地方都可以用User代替

第二种方式

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

在com.lyj.entity包下的所有实体类都可以使用类名首字母小写的方式引用(如com.lyj.entity.UserInf用userInf代替)

也可以在实体类加上注解的方式自定义别名

@Alias(“user”)

public class UserInf { … }

6 settings(设置)

可以为mybatis增加设置

数据库驼峰名转换设置

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

log日志设置显示

ResultMap(结果集映射)

================

为了解决数据映射问题而生

1 解决数据库与实体类属性名不一致问题

解决的问题:属性名和字段名不一致

因为各种原因,数据库的属性字段无法和实体类的属性字段一一对应。

举例:

现在数据库表属性为:

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

实体类属性值为:

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

查询语句:

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

这样查询,因为pwd在实体类中并不存在,在注入值时无法注入。出现password属性为空的情况。

解决方案

使用别名(可简写 pwd password)

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

使用结果集映射->ResultMap 【推荐】

5年码农的我整理了MyBatis从入门到实战,想精通看这一篇就够了

2 解决多对一结果集映射(association关联属性)

多对一理解:

  • 多个学生对应一个老师。

  • 数据库概念理解:学生拥有一个tid与教师id对应。

小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

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

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

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
img

最后

分享一套我整理的面试干货,这份文档结合了我多年的面试官经验,站在面试官的角度来告诉你,面试官提的那些问题他最想听到你给他的回答是什么,分享出来帮助那些对前途感到迷茫的朋友。

面试经验技巧篇
  • 经验技巧1 如何巧妙地回答面试官的问题
  • 经验技巧2 如何回答技术性的问题
  • 经验技巧3 如何回答非技术性问题
  • 经验技巧4 如何回答快速估算类问题
  • 经验技巧5 如何回答算法设计问题
  • 经验技巧6 如何回答系统设计题
  • 经验技巧7 如何解决求职中的时间冲突问题
  • 经验技巧8 如果面试问题曾经遇见过,是否要告知面试官
  • 经验技巧9 在被企业拒绝后是否可以再申请
  • 经验技巧10 如何应对自己不会回答的问题
  • 经验技巧11 如何应对面试官的“激将法”语言
  • 经验技巧12 如何处理与面试官持不同观点这个问题
  • 经验技巧13 什么是职场暗语

面试真题篇
  • 真题详解1 某知名互联网下载服务提供商软件工程师笔试题
  • 真题详解2 某知名社交平台软件工程师笔试题
  • 真题详解3 某知名安全软件服务提供商软件工程师笔试题
  • 真题详解4 某知名互联网金融企业软件工程师笔试题
  • 真题详解5 某知名搜索引擎提供商软件工程师笔试题
  • 真题详解6 某初创公司软件工程师笔试题
  • 真题详解7 某知名游戏软件开发公司软件工程师笔试题
  • 真题详解8 某知名电子商务公司软件工程师笔试题
  • 真题详解9 某顶级生活消费类网站软件工程师笔试题
  • 真题详解10 某知名门户网站软件工程师笔试题
  • 真题详解11 某知名互联网金融企业软件工程师笔试题
  • 真题详解12 国内某知名网络设备提供商软件工程师笔试题
  • 真题详解13 国内某顶级手机制造商软件工程师笔试题
  • 真题详解14 某顶级大数据综合服务提供商软件工程师笔试题
  • 真题详解15 某著名社交类上市公司软件工程师笔试题
  • 真题详解16 某知名互联网公司软件工程师笔试题
  • 真题详解17 某知名网络安全公司校园招聘技术类笔试题
  • 真题详解18 某知名互联网游戏公司校园招聘运维开发岗笔试题

资料整理不易,点个关注再走吧

何应对面试官的“激将法”语言

  • 经验技巧12 如何处理与面试官持不同观点这个问题
  • 经验技巧13 什么是职场暗语

[外链图片转存中…(img-AiHVziy1-1711465936082)]

面试真题篇
  • 真题详解1 某知名互联网下载服务提供商软件工程师笔试题
  • 真题详解2 某知名社交平台软件工程师笔试题
  • 真题详解3 某知名安全软件服务提供商软件工程师笔试题
  • 真题详解4 某知名互联网金融企业软件工程师笔试题
  • 真题详解5 某知名搜索引擎提供商软件工程师笔试题
  • 真题详解6 某初创公司软件工程师笔试题
  • 真题详解7 某知名游戏软件开发公司软件工程师笔试题
  • 真题详解8 某知名电子商务公司软件工程师笔试题
  • 真题详解9 某顶级生活消费类网站软件工程师笔试题
  • 真题详解10 某知名门户网站软件工程师笔试题
  • 真题详解11 某知名互联网金融企业软件工程师笔试题
  • 真题详解12 国内某知名网络设备提供商软件工程师笔试题
  • 真题详解13 国内某顶级手机制造商软件工程师笔试题
  • 真题详解14 某顶级大数据综合服务提供商软件工程师笔试题
  • 真题详解15 某著名社交类上市公司软件工程师笔试题
  • 真题详解16 某知名互联网公司软件工程师笔试题
  • 真题详解17 某知名网络安全公司校园招聘技术类笔试题
  • 真题详解18 某知名互联网游戏公司校园招聘运维开发岗笔试题

[外链图片转存中…(img-Q7myyHG0-1711465936082)]

资料整理不易,点个关注再走吧

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值