零基础学习【Mybatis】这一篇就够了

news2024/11/16 11:35:52

Mybatis

  • 查询
    • resultType使用
    • resultMap使用
    • 单条件查询
    • 多条件查询
    • 模糊查询
    • 返回主键
  • 动态SQL
    • if
    • choose
    • set
    • foreach
    • sql片段
  • 配置文件
  • 注解
    • 增删改查
    • 结果映射

查询

resultType使用

当数据库返回的结果集中的字段和实体类中的属性名一一对应时, resultType可以自动将结果封装到实体中

在这里插入图片描述

resultMap使用

当数据库返回的结果集中的字段和实体类中的属性名存在不对应情况时,可以使用 resultMap 自定义映射关系

在这里插入图片描述

面试题: resultType和resultMap使用区别

单条件查询

在这里插入图片描述

多条件查询

在这里插入图片描述

模糊查询

在这里插入图片描述

面试题:#和$的区别

  • #表示占位符, 相当于JDBC中的?, 底层工作的是PreparedStetement对象, SQL只编译一次, 而且没有SQL注入问题
  • $ 表示字符串拼接, 底层工作的是Statement对象, 每次SQL都会重新编译, 而且存在SQL注入问题

返回主键

向数据库保存一个用户后, 然后在控制台记录下此用户的主键值(id)

在这里插入图片描述

动态SQL

在Mybatis中,动态SQL是通过下面几个标签来实现的:

  • if,choose 用于条件判断
  • where,set 用于格式控制
  • foreach 用于循环遍历

if

在这里插入图片描述

  • if标签用于单分支条件判断, 相当于java中的if关键字
  • where标签作用:
    1. 当where代码块中的条件都不成立的时候, where代码块不生效
    2. 当where代码块中的条件至少有一个成立的时候
      在代码块之前加入一个where关键字
      当代码块以and | or开头的时候,它会帮你去掉第一个and | or

在这里插入图片描述

choose

在这里插入图片描述

  • choose 用于包含多个条件
  • when 用于编写某个条件
  • otherwise所有的when都判断失败时,进入此分支

在这里插入图片描述

set

  • set标签的作用:
    1. 在代码块之前加入一个set关键字
    2. 删除掉代码块中的最后一个,
    3. set代码块中至少要有一个条件是成立

在这里插入图片描述

foreach

  • foreach 循环遍历
    collection=“collection” 指定要遍历的集合或者数组
    item=“item” 指定临时变量
    separator=“,” 指定分隔符
    open=“(” 指定开始字符
    close=“)” 指定结束字符

  • collection会根据传入参数的类型不同而采用不同的值
    集合—collection
    数组—array
    实体—实体的属性

在这里插入图片描述

sql片段

sql片段的作用是将代码中重复的sql,提取出来达到复用的目的

  • 定义SQL片段: <sql id="selectUser"></sql>
  • 引用SQL片段: <include refid="selectUser"></include>

在这里插入图片描述

配置文件

  • sqlMapConfig.xml 此文件中的标签有严格的顺序要求, 可以省略一部分, 但是不能乱序
  • 主要选项
    properties: 引入外部的properties文件
    typeAlias: 给映射文件中实体类起别名
    environments: 用于配置数据库连接信息和事务管理器
    mappers: 用于引入映射文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

    <!--引入一个properties的配置文件-->
    <properties resource="jdbc.properties" />

    <!--别名: 应用在映射文件中-->
    <typeAliases>
        <!--type 指定原始类型  alias 指定别名-->
        <!--<typeAlias type="com.itheima.domain.User" alias="user" />-->
        <!--指定一个包名: 只要是在这个包之下的类,都会自动产生一个别名, 规则就是类名首字母消息-->
        <package name="com.itheima.domain"/>
    </typeAliases>

    <!--
        环境: environments  可以配置多个数据库配置
        default 用于指定使用哪个环境
    -->
    <environments default="development">
        <!--配置开发环境-->
        <environment id="development">
            <!--事务管理器-->
            <transactionManager type="JDBC"/>

            <!--数据源-->
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>

        <!--配置测试环境-->
        <environment id="test">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="测试驱动"/>
                <property name="url" value="测试数据库连接"/>
                <property name="username" value="测试用户名"/>
                <property name="password" value="测试密码"/>
            </dataSource>
        </environment>
    </environments>

    <!--导入sql映射文件-->
    <mappers>
        <!--方式1: 直接导入映射文件(了解)-->
        <!--<mapper resource="mappers/UserMapper.xml"/>-->
        <!--方式2: 写接口路径-->
        <!--<mapper class="com.itheima.mapper.UserMapper" />-->
        <!--方式3: 直接写mapper接口所在的包(保证最后Mapper接口和Mapper.xml会编译到同一个目录下,并且名字一致)-->
        <package name="com.itheima.mapper"/>
    </mappers>

</configuration>

在这里插入图片描述

注解

使用注解书写SQL其实是对使用XML书写SQL的一种替代方式,其功能基本一致。

两种方式各有优缺点, 没有谁好谁坏之分, 具体看公司选择

在一个项目中是允许xml和注解混用的,但是对于同一个方法来讲,只能使用一种形式

非动态sql,使用注解简单写 但是对于动态sql,xml就相对简单了

增删改查

在这里插入图片描述

结果映射

在这里插入图片描述

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

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

相关文章

react高级组件ProForm实现输入框搜索

实现界面 <Col span{12}><ProForm.Itemname"name"label"推荐用户"><AutoCompleteclassName"pro-field pro-field-md"placeholder"请输入用户名"options{NameArr}onSearch{debounce(searchUser, 500)}onSelect{onSelect…

【北京迅为】《i.MX8MM嵌入式Linux开发指南》-第四篇 嵌入式Linux系统移植篇-第七十三章内核添加网卡驱动

i.MX8MM处理器采用了先进的14LPCFinFET工艺&#xff0c;提供更快的速度和更高的电源效率;四核Cortex-A53&#xff0c;单核Cortex-M4&#xff0c;多达五个内核 &#xff0c;主频高达1.8GHz&#xff0c;2G DDR4内存、8G EMMC存储。千兆工业级以太网、MIPI-DSI、USB HOST、WIFI/BT…

有趣的PHP小游戏——猜数字

猜数字 这个游戏会随机生成一个1到100之间的数字&#xff0c;然后你需要猜测这个数字是什么。每次你输入一个数字后&#xff0c;程序会告诉你这个数字是“高了”还是“低了”&#xff0c;直到你猜对为止&#xff01; 使用指南&#xff1a; 代码如下&#xff0c;保存到一个p…

大模型卷入医学图像!PFPs:使用大型视觉和语言模型的提示引导灵活病理分割,用于多样化潜在结果

PS&#xff1a;写在前面&#xff0c;近期感谢很多小伙伴关注到我写的论文解读&#xff0c;我也会持续更新吖~同时希望大家多多支持本人的公主号~ 想了解更多医学图像论文资料请移步公主&#x1f478;号哦~~~后期将持续更新&#xff01;&#xff01; 关注我&#xff0c;让我们一…

【嵌入式】STM3212864点阵屏使用SimpleGUI单色屏接口库——(2)精简字库

一 开源库简介与移植 最近一个项目需要用12864屏幕呈现一组较为复杂的菜单界面&#xff0c;本着不重复造轮子的原则找到了SimpleGUI开源库。 开源地址&#xff1a;SimpleGUI: 一个面向单色显示屏的开源GUI接口库。 SimpleGUI是一款针对单色显示屏设计的接口库。相比于传统的GUI…

kali里面的vulhub靶场搭建

第一步&#xff1a;安装docker镜像容器 sudo apt install docker.io 第二步&#xff1a;开启docker镜像容器 先查看一下docker有没有下载成功 docker -v 再查看一下docker的运行状态 systemctl status docker 第三步&#xff1a;下载docker-compose环境 apt install do…

94 二叉树的中序遍历

解题思路&#xff1a; \qquad 首先理解中序遍历&#xff1a;left node——root——right node。 \qquad 中序遍历的起始点为该树最左边的非空元素。本题可以使用递归、DFS&#xff08;迭代&#xff09;解决。 递归法&#xff1a; \qquad 重复的基础操作&#xff1a;输出roo…

甘肃西北风情贝壳面你吃过吗?

在西北的甘肃&#xff0c;有一种传统面食——麻食&#xff0c;以其独特的制作工艺和浓郁的地方风味&#xff0c;成为了当地人民餐桌上的宠儿。麻食&#xff0c;又被称为“麻什”“麻食子”等&#xff0c;是一种手工搓制而成的面食。它的形状酷似猫耳朵&#xff0c;小巧玲珑&…

超有趣的视觉欺骗

by 游梦 关键词&#xff1a;蜘蛛侠、室内映射、假室内 大家一起先找茬&#xff0c;半分钟找出下图中穿帮镜头 &#xff08;图源&#xff1a;https://zhuanlan.zhihu.com/p/159439811&#xff09; 答案揭晓&#xff1a; 可以看到室内门的位置&#xff0c;在建筑不同视角下的位…

为 Laravel 提供生产模式下的容器化环境:打造现代开发环境的终极指南

为 Laravel 提供生产模式下的容器化环境&#xff1a;打造现代开发环境的终极指南 在现代开发中&#xff0c;容器化已经成为一种趋势。使用 Docker 可以让我们轻松地管理和部署应用程序。本文将带你一步步构建一个高效的 Laravel 容器化环境&#xff0c;确保你的应用程序在开发…

Modbus从站模拟软件

下载地址&#xff1a; Modbus从站模拟软件资源-CSDN文库

linux创建用户并免密切换

useradd ansible passwd ansible 加入到wheel组 sudo usermod -G wheel ansible 编辑文件visudo ansible ALL(ALL) NOPASSWD:ALL chage -M 99999 ansible #设置密码永不过期

2024上半年热门内容透视 | 品牌种草解析

2024年上半年&#xff0c;小红书平台“考公上岸”、“不确定性”、“重养自己一遍”、“人生是旷野”、“原生家庭顶配”等话题热议之下&#xff0c;透露着消费者怎样的需求&#xff1f; 综合热门内容及小红书用户的分享发现&#xff0c;变数和不确定性成为新常态&#xff0c;消…

PTrade常见问题系列18

客户反馈某代码L1快照有延迟&#xff1f; 客户反馈某代码9.30.12的快照在9.30.12策略没有获取到&#xff0c;在9.30.17才获取到&#xff1f; 1、由于交易所的快照不是严格按照3s下发的&#xff0c;例如快照在9.30.12.300更新了&#xff0c;客户策略在9.30.12.100执行到&#…

什么是文档签名证书?如何获取文档签名证书?

在数字化高速发展的当今时代&#xff0c;各行各业都开始向数字化转型&#xff0c;随着国家大力倡导和积极推进数字化&#xff0c;电子文件的应用越来越广泛。然而&#xff0c;电子文件包含了个人隐私、金融交易、电子处方、合同协议等敏感信息&#xff0c;如何确保这些重要文件…

Python开发框架FastAPI系列(1. 初体验)

本文为系列文章Python开发框架FastAPI系列的第一部分。 缘起 其实Python的Web开发框架已经有很多了&#xff0c;包括老将Django和后起之秀Flask都做得很好&#xff0c;各有各的特色。那么为什么FastAPI作为一个后来者&#xff0c;短时间内就人气飙升呢&#xff1f;我也是看到…

【linux】【操作系统】初始化程序之main.c源码阅读

/init/main.c是Linux操作系统启动过程的核心部分&#xff0c;它负责初始化硬件、设备、内存和系统服务&#xff0c;以及启动第一个用户进程&#xff0c;为后续的系统运行奠定基础。 详细解析 1. 内联函数定义 fork, pause, setup, sync: 这些函数被声明为内联&#xff0c;意…

解决secureCRT乱码设置UTF-8显示中文

永久性配置UTF-8 在SecureCRT的安装文件夹中搜索“Default.ini” 找到D:“Filenames Always Use UTF8”00000000&#xff0c;将最后的0变成1&#xff0c;即&#xff1a;D:“Filenames Always Use UTF8”00000001 将S:”Output Transformer Name”Default修改为S:”Output Tran…

如何使用 PHP Simple HTML DOM Parser 轻松获取网页中的特定数据

背景介绍 网页数据的抓取已经成为数据分析、市场调研等领域的重要工具。无论是获取产品价格、用户评论还是其他公开数据&#xff0c;网页抓取技术都能提供极大的帮助。今天&#xff0c;我们将探讨如何使用 PHP Simple HTML DOM Parser 轻松获取网页中的特定数据。PHP Simple H…

SPSSAU | 最好最差权重BWM原理及案例实操分析

BWM&#xff08;best-worse-method&#xff0c;最好最差法&#xff09;是一种多准则决策方法&#xff0c;由Jafar Rezaei于2015年提出&#xff0c;其通常用于确定决策标准的权重。其原理是比如5个指标&#xff0c;如果以前AHP就需要5个指标两两的相对重要性数据。但是现在简化为…