谈谈mybatis的理解(一)

mybatis不允许方法的重载,因为ID不能重复

mybatis

为什么要使用mybatis?

JDBC的弊端

硬编码:SQL语句存在Java代码中,不能很好的分离数据库语句和Java语句,造成代码不易维护

代码重复度高:大量重复的代码

SQL参数固定 :SQL语句的参数固定,使得SQL语句不灵活,无法满足多变的场景

底层技术:JDBC属于底层的技术,不支持分布式,缓存等技术,对于复杂场景的应对不好

ORM模型:ORM 模型是数据库的表和简单 Java 对象(Plain Ordinary Java Object,简称 POJO)的映射关系模型,主要解决数据库数据和 POJO 对象的相互映射

java类和数据库的映射关系:

java类数据库表
属性字段

常见的ORM模型

  1. Hibernate:Hibernate 是一个 全自动 的 ORM 模型,Hibernate 可以自动生成 SQL 语句,自动执行
  2. MyBatis:MyBatis 是一款 半自动 的 ORM 模型,它支持定制化 SQL、存储过程以及高级映射
Mybatis的映射器
select元素

语法规则:< select 属性=“值”>查询类SQL语句</ select >

属性说明
id唯一标识,和接口中的方法名一致
parameterType参数的类型(入参)
resultType结果的类型
resultMap复杂的结果集映射关系

注意:小于号<需要使用转义字符进行代替 <

insert元素

语法规则:< insert 属性=“值”>新增类SQL语句</ insert >

注意:新增可以添加主键回调

属性说明
keyProperty表示以哪个列作为属性的主键,不能和 keyColumn 同时使用
keyColumn指明哪一列是主键,不能和 keyProperty 同时使用
useGeneratedKeys使用 JDBC 的 getGeneratedKeys 方式来取有数据库内部生成的主键

主键回调:当主键在数据库中为自增字段时,新增成功后,回调主键

<insert id="addStudent" parameterType="Student" keyProperty="sid"useGeneratedKeys="true">insert into student(sname,birthday,ssex,classid)values(#{sname},#{birthday},#{ssex},#{classid})
</insert>

update元素

语法规则:< update 属性=“值”>查询类SQL语句</ update >

<update id="updateStudent" parameterType="Student">update student set sname=#{sname},birthday=#{birthday},ssex = #{ssex},classid = #{classid} where sid = #{sid}	 
</update>

delete元素

语法规则:< delete 属性=“值”>查询类SQL语句</ delete >

<delete id="delStudent" parameterType="int">delete from student where sid = #{v}
</delete>

resultMap元素

为什么要使用 resultMap 元素?

因为数据库的字段名和java的属性名不一致

存储映射结果集

type表示需要映射的实体类,id是resultMap的唯一标识

属性说明
column对应数据库中的字段名
property要映射到实体类的属性名
<resultMap type="Student" id="stu_class_Map"><result column="sid" property="sid"/><result column="sname" property="sname"/><result column="birthday" property="birthday"/><result column="ssex" property="ssex"/><result column="classid" property="classid"/>
</resultMap><select id="findAllStudentAndClass" resultMap="stu_class_Map">select * from Student 
</select>

多表联查

什么是级联:级联(cascade),是指多个对象之间的映射关系,建立数据之间的级联关系提高管理效率

一对一级联

一对一使用association

	<resultMap type="Student" id="stu_class_Map"><result column="sid" property="sid"/><result column="sname" property="sname"/><result column="birthday" property="birthday"/><result column="ssex" property="ssex"/><result column="classid" property="classid"/><!-- 一对一 --><association property="bj"><result column="classid" property="classid" /><result column="classname" property="classname"/></association></resultMap><select id="findAllStudentAndClass"  resultMap="stu_class_Map" >select * from student left join class on student.classid = class.classid</select>

在多表联查中没有显示映射的字段不会被赋值

一对多级联

一对多使用collection

	<resultMap type="Banji" id="bj_stu_Map"><result column="classid" property="classid" /><result column="classname" property="classname" /><!-- 一对多  --><collection property="slist" ofType="Student"><result column="sid" property="sid"/><result column="sname" property="sname"/><result column="birthday" property="birthday"/><result column="ssex" property="ssex"/><result column="classid" property="classid"/></collection></resultMap><select id="findAllBanjiAndStu" resultMap="bj_stu_Map">select * from class left join student on class.classid = student.classid</select>

一对多联查的步骤:

  1. 创建“一”方实体类(以集合的形式级联“多”方对象)
  2. 创建“多”方对象(创建“多”方的实体类)
  3. 创建映射器
  4. 实现一对多级联(利用collection元素实现一对多的级联)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/669545.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++:哈希表的线性探测(模拟实现)

哈希表的增删查改的效率很高&#xff0c;是O&#xff08;1&#xff09;&#xff0c;比搜索二叉树要快很多。那么他是怎么实现的呢&#xff1f;他与计数排序有点相似就是通过映射的方式实现。不过在哈希表中不需要开这么的数据&#xff0c;它只需要开一部分空间然后使用除留余数…

【算法与数据结构】583、72、LeetCode两个字符串的删除操作+编辑距离

文章目录 一、583、两个字符串的删除操作二、72、编辑距离三、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、583、两个字符串的删除操作 思路分析&#xff1a;本题的思路和115、不同的子序列差不多&#xff0c;只是变成…

【Java EE初阶十】多线程进阶二(CAS等)

1. 关于CAS CAS: 全称Compare and swap&#xff0c;字面意思:”比较并交换“&#xff0c;且比较交换的是寄存器和内存&#xff1b; 一个 CAS 涉及到以下操作&#xff1a; 下面通过语法来进一步进项说明&#xff1a; 下面有一个内存M&#xff0c;和两个寄存器A,B; CAS(M,A,B)&am…

minio怎么创建bucket

在使用docker-compose安装的MinIO环境中创建bucket&#xff08;存储桶&#xff09;通常涉及到使用MinIO的客户端工具mc&#xff08;MinIO Client&#xff09;。以下是如何使用mc来创建一个名为ability-bucket的bucket的步骤&#xff1a; 步骤 1: 下载并配置mc客户端 下载mc&am…

比较Kamailio和OpenSIPS的重写contact函数

Kamailio&#xff1a;调用set_contact_alias()之后&#xff0c;在原有的contact的后面增加参数&#xff0c;具体地说&#xff0c;就是网络地址&#xff0c;网络端口和transport&#xff0c;好处是收到后续请求之时可以恢复原有contact的内容 OpenSIPS&#xff1a;调用fix_nate…

synchronized内部工作原理

作者简介&#xff1a; zoro-1&#xff0c;目前大二&#xff0c;正在学习Java&#xff0c;数据结构&#xff0c;javaee等 作者主页&#xff1a; zoro-1的主页 欢迎大家点赞 &#x1f44d; 收藏 ⭐ 加关注哦&#xff01;&#x1f496;&#x1f496; synchronized内部工作原理 syn…

矿泉水市场调研:预计2029年将达到83亿美元

矿泉水为国民饮水消费升级的方向&#xff0c;估算我国矿泉水市场规模约472亿元&#xff0c;成长性好。我们按照水种将包装水划分为矿泉水、纯净水、天然水及其他&#xff0c;根据多个第三方数据来源数据&#xff0c;我们估算矿泉水2017年瓶装与桶装合计市场销售规模约472亿元&a…

深入理解指针(3)

⽬录 1. 字符指针变量 2. 数组指针变量 3. ⼆维数组传参的本质 4. 函数指针变量 5. 函数指针数组 6. 转移表 1. 字符指针变量 在指针的类型中我们知道有⼀种指针类型为字符指针 char* ; ⼀般使⽤: int main() {char ch w;char *pc &ch;*pc w;return 0; } 还有…

属性“xxxx”在类型“ArrayConstructor”上不存在。是否需要更改目标库? 请尝试将 “lib” 编译器选项更改为“es2015”或更高版本。

使用vscode编写vue&#xff0c;在使用elementUI时&#xff0c;发现代码中的form报错如下&#xff1a; 属性“form”在类型“ArrayConstructor”上不存在。是否需要更改目标库? 请尝试将 “lib” 编译器选项更改为“es2015”或更高版本。 解决方法&#xff1a; 打开jsconfig.…

Springboot拦截器+redis实现暴力请求拦截

在实际项目开发部署过程中&#xff0c;我们需要保证服务的安全性和可用性&#xff0c;当项目部署到服务器后&#xff0c;就要考虑服务被恶意请求和暴力攻击的情况。如何防止我们对外的接口被暴力攻击&#xff1f;下面的教程&#xff0c;通过Springboot提供的拦截器和Redis 针对…

快速掌握Vue.js框架:从入门到实战

一、引言 Vue.js,作为一款广受欢迎的渐进式JavaScript框架,以其轻量级、易用性和高效性在前端开发领域占据了一席之地。Vue.js遵循MVVM(Model-View-ViewModel)设计模式,它通过双向数据绑定机制简化了开发者对用户界面与底层数据模型之间关系的处理,使得构建现代Web应用变…

TOP100-二叉数

1.94. 二叉树的中序遍历 给定一个二叉树的根节点 root &#xff0c;返回 它的 中序 遍历 。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[1,3,2]示例 2&#xff1a; 输入&#xff1a;root [] 输出&#xff1a;[]示例 3&#xff1a; 输入&#xf…

第8章 多线程

8.1 线程概述 人们在日常生活中&#xff0c;很多事情都是可以同时进行的。例如&#xff0c;一个人可以一边听音乐&#xff0c;一边打扫房间&#xff0c;可以一边吃饭&#xff0c;一边看电视。在使用计算机时&#xff0c;很多任务也是可以同时进行的。例如&#xff0c;可以一边…

uniapp uni.redirectTo() 跳转失效

原代码&#xff1a; uni.redirectTo({url: /pages/mine/Mine }) 想实现的效果是用户登录成功后跳转至”我的“页面&#xff0c;但是点击登录按钮后可以成功打印出登录信息&#xff0c;却不跳转页面。 原因是我在 tabBar 中配置了 Mine 页面。 "tabBar": {"b…

对多面体数据进行裁剪和加盖的功能

开发环境&#xff1a; Windows 11 家庭中文版Microsoft Visual Studio Community 2019VTK-9.3.0.rc0vtk-example demo解决问题&#xff1a;对多面体数据进行裁剪和加盖的功能。 关键点&#xff1a; 创建了一个平面&#xff0c;并将其定位在输入多面体数据的中心位置&#xff…

详解洛谷P1352 没有上司的舞会(树形DP经典例题)

题目 没有上司的舞会 - 洛谷 思路 这是一道非常裸的树形DP&#xff0c;对于初学树形DP的OIer来说&#xff0c;是一道十分良心的题 我们可以设: dp[x][0]表示以x为根的子树,且x不参加舞会的最大快乐值 dp[x][1]表示以x为根的子树&#xff0c;且x参加了舞会的最大快乐值 则有 …

爬虫工作量由小到大的思维转变---<第四十四章 Scrapyd 用gerapy管理多台机器爬虫>

前言: 之前讲过关于如何在gerapy中部署本地爬虫, 爬虫工作量由小到大的思维转变---&#xff1c;第三十四章 Scrapy 的部署scrapydGerapy&#xff1e;_gerapy如何登录-CSDN博客 爬虫工作量由小到大的思维转变---&#xff1c;第三十五章 Scrapy 的scrapydGerapy 部署爬虫项目&…

SpringBoot:配置相关知识点

SpringBoot&#xff1a;多环境配置 配置知识点demo&#xff1a;点击查看LearnSpringBoot02 点击查看更多的SpringBoot教程 一、SpringBootApplication SpringBootApplication 来标注一个主程序类&#xff0c;说明这是一个Spring Boot应用&#xff0c;运行这个类的main方法来…

睿尔曼超轻量仿人机械臂-- RM65-B手眼标定使用说明

一、前言 机器人的视觉系统分为固定场景视觉系统和运动的「手-眼」视觉系统。相机与机器人手臂末端&#xff0c;构成手眼视觉系统。根据相机在机器人安装位置的不同&#xff0c;手眼视觉系统分为Eye-in-Hand系统&#xff08;眼在手上&#xff09;和Eye-to-Hand系统&#xff08…

Javascript | 打印菱形

Javascript打印菱形&#xff0c;在校大学生可以拿来糊弄作业&#xff08;笑&#xff09; var str ; for (var i 1; i < 9; i) {if (i < 5) {for (var k1 1; k1 < 5 - i; k1) {str ;}} else {for (var k2 1; k2 < i - 5; k2) {str ;}}if (i < 5) {for (…