MyBatis入门操作

"MyBatis是一个优秀的持久层框架,它解决了原始JDBC操作中的资源浪费、SQL硬编码和数据封装等问题。通过使用数据库连接池、XML配置SQL以及反射和内省技术,MyBatis实现了SQL语句与Java代码的分离以及数据的自动映射。本文介绍了MyBatis的开发步骤,包括添加依赖、创建数据表、编写实体类和映射文件,还探讨了#{}
摘要由CSDN通过智能技术生成

MyBatis的简介

原始jdbc操作的分析

原始jdbc开发存在的问题如下:

  • 数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能。
  • sql 语句在代码中硬编码,造成代码不易维护,实际应用sql变化的可能较大,sql变动需要改变java代码。
  • 查询操作时,需要手动将结果集中的数据手动封装到实体中。插入操作时,需要手动将实体的数据设置到sql语句的占位符位置。

应对上述问题给出的解决方案:

  • 使用数据库连接池初始化连接资源。
  • 将sql语句抽取到xml配置文件中。
  • 使用反射、内省等底层技术,自动将实体与表进行属性与字段的自动映射。

MyBatis的快速入门

MyBatis开发步骤

MyBatis开发步骤:
① 添加MyBatis的坐标
在这里插入图片描述
② 创建user数据表
在这里插入图片描述
③ 编写User实体类
在这里插入图片描述
在这里插入图片描述
④ 编写映射文件UserMapper.xml
在这里插入图片描述
#{}和${}的区别是什么?

  • $ {} 是 Properties 文件中的变量占位符,它可以用于标签属性值和 sql 内部,属于静态文本替换,比如${driver}会被静态替换为com.mysql.jdbc. Driver。
  • #{}是 sql 的参数占位符,MyBatis 会将 sql 中的#{}替换为? 号,在 sql 执行前会使用 PreparedStatement 的参数设置方法,按序给 sql 的? 号占位符设置参数值,比如 ps.setInt(0, parameterValue),#{item.name} 的取值方式为使用反射从参数对象中获取 item 对象的 name 属性值,相当于 param.getItem().getName()。

⑤ 编写核心文件SqlMapConfig.xml
在这里插入图片描述
⑥ 编写测试类
在这里插入图片描述
在这里插入图片描述

MyBatis的映射文件概述

在这里插入图片描述

MyBatis的增删改查操作

MyBatis的插入数据操作

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

MyBatis的修改数据操作

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

MyBatis的删除数据操作

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

MyBatis的核心配置文件概述

MyBatis核心配置文件层级关系

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

MyBatis的相应API

SqlSession工厂构建器SqlSessionFactoryBuilder

在这里插入图片描述

SqlSession工厂对象SqlSessionFactory

在这里插入图片描述

SqlSession会话对象

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

身影王座

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值