WEB04MyBatis

Mybatis

mybatis查询

准备

准备工作

  • 在目前的数据库中添加一张数据表emp

  • 将资料中提供的day04-01-mybatis导入的目前的工程中

  • 修改配置文件中的数据库的账户和密码

  • 观察实体类中的属性和数据表中的字段的对应关系

查询结果封装

查询所有

  • SQL语句

    select * from emp;

  • 接口方法

    @Select("select * from emp")public List<Emp> findAll();

数据封装

  • 实体类属性名 和 数据库表查询返回的字段名一致,mybatis会自动封装。

  • 如果实体类属性名 和 数据库表查询返回的字段名不一致,不能自动封装。

  • 开启驼峰命名:如果字段名与属性名符合驼峰命名规则,mybatis会自动通过驼峰命名规则映射。

    #开启驼峰命名自动映射,即从数据库字段名 a_column 映射到Java 属性名 aColumn。

    <setting name="mapUnderscoreToCamelCase" value="true"/>

  • 起别名:在SQL语句中,对不一样的列名起别名,别名和实体类属性名一样。

    @Select("select id, username, password, name, gender, image, job, entrydate ed, dept_id deptId, create_time createTime, update_time updateTime from emp")public Emp findAll();

  • 手动结果映射:通过 @Results及@Result 进行手动结果映射。

    @Select("select * from emp")@Results({ @Result(column = "dept_id", property = "deptId"), @Result(column = "entrydate", property = "ed") })public Emp findAll();

条件查询

查询(条件查询)

  • SQL语句

    select * from emp where name = '张三丰' and gender = 1 and entrydate between '2010-01-01' and '2020-01-01 ';

  • 接口方法

    @Select("select * from emp where name = #{name} and gender = #{gender} and entrydate between #{begin} and #{end}")List<Emp> findList(@Param("name") String name, @Param("gender") Short gender, @Param("begin") LocalDate begin, @Param("end") LocalDate end);

@Param

  • @Param 标注在方法参数的前面,用于声明参数在#{}中的名字

  • 后面SpringBoot2.x整合mybatis之后,这个注解可以不再添加

模糊查询

查询(模糊查询)

  • SQL语句

    select * from emp where name like '%张%' and gender = 1 and entrydate between '2010-01-01' and '2020-01-01 ';

  • 接口方法(性能低、不安全、存在SQL注入问题)

    @Select("select * from emp where name like '%${name}%' and gender = #{gender} and entrydate between #{begin} and #{end}")List<Emp> findList(@Param("name") String name, @Param("gender") Short gender, @Param("begin") LocalDate begin, @Param("end") LocalDate end);@Select("select * from emp where name like concat('%',#{name},'%') and gender = #{gender} and entrydate between #{begin} and #{end}")List<Emp> findList(@Param("name") String name, @Param("gender") Short gender, @Param("begin") LocalDate begin, @Param("end") LocalDate end);

xml书写sql

XML映射文件

  • 使用Mybatis的注解,主要是来完成一些简单的增删改查功能。

  • 如果需要实现复杂的SQL功能,建议使用XML来配置映射语句。

  • 官方说明:入门_MyBatis中文网

规范

  • XML映射文件的名称与Mapper接口名称一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)。

  • XML映射文件的namespace属性为Mapper接口全限定名一致。

  • XML映射文件中sql语句的id与Mapper 接口中的方法名一致,并保持返回类型一致。

经典报错

  • 对于同一个方法,XML和注解中同时为其编写了sql

  • 约定好的对应关系有误

  • MybatisX 是一款基于 IDEA 的快速开发Mybatis的插件,为效率而生

动态sql

介绍

动态SQL

  • 随着用户的输入或外部条件的变化而变化的SQL语句,我们称为 动态SQL。

<if> <where> <set>

<if>

  • <if>:用于判断条件是否成立。使用test属性进行条件判断,如果条件为true,则拼接SQL。

  • <where>:where 元素只会在子元素有内容的情况下才插入where子句。而且会自动去除子句的开头的AND 或OR。

动态更新员工信息,如果更新时传递有值,则更新;如果更新时没有传递值

  • <set>:动态地在行首插入 SET 关键字,并会删掉额外的逗号。(用在update语句中)

<foreach>

<foreach>

  • SQL语句

    delete from emp where id in (1,2,3);

  • 接口方法

    //批量删除

  • public void deleteByIds(@Param("ids") List<Integer> ids);

  • XML映射文件

    <delete id="deleteByIds">delete from emp where id in<foreach collection="ids" item="id" separator="," open="(" close=")">#{id}</foreach></delete>

属性

  • collection:集合名称

  • item:集合遍历出来的元素/项

  • separator:每一次遍历使用的分隔符

  • open:遍历开始前拼接的片段

  • close:遍历结束后拼接的片段

<sql><include>

sql片段(了解)

  • <sql>:定义可重用的 SQL 片段。

  • <include>:通过属性refid,指定包含的sql片段。

配置文件

SqlMapConfig.xml

主配置文件

  • settings:控制一些全局配置项的开闭

  • mappers:用于指定Mapper接口的位置

  • environments: 配置事务管理器和数据库连接信息

数据库连接池

  • 数据库连接池是个容器,负责分配、管理数据库连接(Connection)

  • 它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个

  • 释放空闲时间超过最大空闲时间的连接,来避免因为没有释放连接而引起的数据库连接遗漏

优势

  • 资源重用

  • 提升系统响应速度

  • 避免数据库连接遗漏

标准接口:DataSource

  • 官方(sun)提供的数据库连接池接口,由第三方组织实现此接口。

  • 功能:获取连接 归还连接

常见产品

  • Druid(德鲁伊): 阿里巴巴提供的数据库连接池技术,国内使用率很高,提供了完善的监控机制

  • HikariCP: 日本人开发的连接池技术,号称性能之王,速度最快,SpringBoot2.0默认使用此连接池

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

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

相关文章

苹果电脑清理app垃圾高效清理,无需专业知识

在我们的日常使用中&#xff0c;苹果电脑以其优雅的设计和强大的功能赢得了广泛的喜爱。然而&#xff0c;即便是最高效的设备&#xff0c;也无法免俗地积累各种不必要的文件和垃圾&#xff0c;特别是app垃圾。所以&#xff0c;苹果电脑清理app垃圾高效清理&#xff0c;对于大多…

在Linux系统中配置GitHub的SSH公钥

在Linux系统中配置GitHub的SSH公钥&#xff0c;可以让您无需频繁输入密码即可与GitHub仓库进行交互&#xff0c;提高工作效率。以下是配置步骤: 第一步&#xff1a; 检查SSH密钥是否存在 首先&#xff0c;检查您的用户目录下的.ssh文件夹中是否已有SSH密钥。打开终端&#xff0…

ESD管ESD113-B1-02EL(S)国产替代型号ULC0342CDNH,ULC0321CDNH

雷卯型号全&#xff0c;能替代大量infineon型号。具体如下&#xff1a; 应用于3.3V高速信号静电保护器件&#xff0c;infineon的ESD113-B1-02EL(DFN1006)和ESD113-B1-02ELS(DFN0603)&#xff0c;交期长&#xff0c;价格高。已经有很多客户选雷卯的 ULC0342CDNH(DFN1006)&#…

人体姿态估计库 mediapipe

在jetson-nx上文件夹中的whl包就能安装了&#xff0c;在PC的windows上直接pip install mediapipe就能安装 whl包参考 零基础入门Jetson Nano——MediaPipe双版本&#xff08;CPUGPU&#xff09;的安装与使用_mediapipe gpu-CSDN博客 目录 1 全身姿态检测 1.1 基本使用 1…

Oracle Database 23ai新特性:增加聚合函数对INTERVAL数据类型支持

在Oracle早期的版本&#xff0c;聚合函数和分析函数MIN/MAX 就支持了INTERVAL 数据类型。但是&#xff0c;当我们使用SUM或AVG函数对INTERVAL 数据类型进行运算时&#xff0c;就会报错。 随着Oracle Database 23ai 的发布&#xff0c;增加了 AVG 以及 SUM 函数对INTERVAL 数据…

VirtualBox 安装 Ubuntu Server24.04

环境&#xff1a; ubuntu-2404-server、virtualbox 7.0.18 新建虚拟机 分配 CPU 核心和内存&#xff08;根据自己电脑实际硬件配置选择&#xff09; 分配磁盘空间&#xff08;根据自己硬盘实际情况和需求分配即可&#xff09; 设置网卡&#xff0c;网卡1 负责上网&#xff0c…

零代码复现SCI!P trend+多模型控制混杂一站式搞定!

今天给大家带来的复现内容是CHARLS数据库的一篇横断面研究文章&#xff0c;文章统计方法部分包括了①基线差异性分析、②线性趋势分析计算P trend、③多模型线性回归控制混杂因素。 这些统计方法风暴统计统统一站式搞定&#xff0c;零代码操作&#xff0c;新手小白也可以轻松上…

linux 发送报文的几种方式

使用nc连接服务并发送16进制&#xff1a;echo -e 7E7E026020000263002002101000010001B7C7 | xxd -r -p |nc 172.16.0.42 20004 telnet 发送报文&#xff1a;1.telnet > open host port > 7E7E026020000263002002101000010001B7C7 socat 方式&#xff1a; echo sdfsdfsdf…

IDEA创建Spring项目无法使用Java8的解决方案

文章目录 一&#xff0c;创建Project&#xff0c;无法选择Java81&#xff0c;无法选择Java82&#xff0c;选择JDK17报错 二&#xff0c;原因分析1&#xff0c;Spring Boot将来会全力支持Java17&#xff0c;不再维护支持Java8的版本 三&#xff0c;解决方案1&#xff0c;使用国内…

构建基于Spring Boot的数据分析平台

构建基于Spring Boot的数据分析平台 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 在当今信息化时代&#xff0c;数据是企业和组织的重要资产。构建一个高效…

Cross Debugging with GDB: Embedded Linux

This is suitable for environments with limited resources and insufficient memory, to avoid out-of-memory errors caused by running gdb. The uclibc platform does not yet support this functionality. 文章目录 Install gdb-multiarch on PCRun gdbserver on DUTPre…

三级_01_网络系统结构与设计的基本原则

1.下列关于RPR技术的描述中&#xff0c;错误的是()。 RPR与FDDI一样使用双环结构 在RPR环中&#xff0c;源节点向目的节点成功发出的数据帧要由目的节点从环中收回 RPR环中每一个节点都执行MPLS公平算法 RPR环能够在50ms内实现自愈 2.下列关于RPR技术的描述中&#xff0c;…

Vue项目使用mockjs模拟后端接口

文章目录 操作步骤1. 安装 mockjs 和 vite-plugin-mock2. 安装 axios3. 创建mock路径4. 配置 viteMockConfig5. 编写第一个mock接口6. 创建 createProdMockServer7. 配置 axios8. 编写请求接口9. 在页面中使用 操作步骤 1. 安装 mockjs 和 vite-plugin-mock vite-plugin-mock …

springboot的健身房预约管理系统-计算机毕业设计源码75535

目录 1 绪论 1.1 选题背景与意义 1.2国内外研究现状 1.3论文结构与章节安排 1.4开发技术 1.4.1 Java技术 1.4.2MVVM模式 1.4.3B/S结构 1.4.4SpringBoot框架 1.4.5 Mysql数据库 2系统分析 2.1 可行性分析 2.1.1经济可行性 2.1.2技术可行性 2.1.3操作可行性 2.2 系…

SpringBoot 自定义异常返回数据格式

Spring Boot 默认异常处理 当我们用 spring boot 开发接口是&#xff0c;当遇到异常时返回的数据格式是如下形式的 {"timestamp": "2024-07-06T02:48:55.79100:00","status": 404,"error": "Not Found","path":…

在 Windows 上安装移动应用和Amazon Appstore

https://support.microsoft.com/zh-cn/windows/在-windows-上安装移动应用和amazon-appstore-f8d0abb5-44ad-47d8-b9fb-ad6b1459ff6c

【Linux】GNU是什么

GNU是一个自由软件项目&#xff0c;其全称是“GNUs Not Unix!”&#xff0c;由理查德斯托曼&#xff08;Richard Stallman&#xff09;于1983年发起。GNU项目的目标是创建一个完全自由的操作系统&#xff0c;包括一整套完全自由的软件工具&#xff0c;以取代Unix系统。这里的“…

matlab 花瓣线绘制

matlab 花瓣线绘制 clc,clear,close all; % 创建一个范围内的 x 和 y 值 x linspace(-1.5, 1.5, 100); y linspace(-1.5, 1.5, 100);% 创建一个网格来表示 x 和 y 值的组合 [X, Y] meshgrid(x, y);% 计算方程的左边和右边的值 LHS1 X.^2 Y.^2; RHS1 X.^4 Y.^4;LHS2 X.…

接口对接json

public AjaxResult zhihuiya(RequestBody ZlRecord zlRecord) {//查看用户或者部门有没有下载次数SysUser user SecurityUtils.getLoginUser().getUser();ZlCount zlCount newLabelMapper.selectUserCount(user.getUserId());if (ObjectUtils.isEmpty(zlCount)){ZlCount zlCo…

vue2-vue3响应式原理

我们先来看一下响应式意味着什么&#xff1f;我们来看一段代码&#xff1a; m有一个初始化的值&#xff0c;有一段代码使用了这个值&#xff1b;那么在m有一个新的值时&#xff0c;这段代码可以自动重新执行&#xff1b; let m 20 console.log(m) console.log(m * 2)m 40上…