当前位置: 首页 > news >正文

MyBatis的xml实现

1.下载插件MyBatisX

 

2.添加依赖

<!--Mybatis 依赖包--><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.3.1</version></dependency><!--mysql驱动包--><dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><scope>runtime</scope></dependency>

3. 配置yml文件

mybatis:mapper-locations: classpath:mapper/*Mapper.xmlconfiguration: # 配置打印 MyBatis 执行的 SQLlog-impl: org.apache.ibatis.logging.stdout.StdOutImplmap-underscore-to-camel-case: true  #自动驼峰转换
# 配置打印 MyBatis 执行的 SQL

注意

mapper为创建的目录名,自己设置,还有Mapper也可以自己设,但是一定要保持一致 

4.创建文件

 ①创建Mapper文件,首先在java目录下创建mapper目录,在mapper目录下常见UserInfoXNMLMapper文件,其次在resource目录下创建mapper目录,在maaper目录下创建同名的UserInfoXNMLMapper(必须一样),如果不一致,会出现spring找不到的情况,项目无法启动

在UserInfoXNMLMapper文件中加入方法

package com.example.demo.mapper;import com.example.demo.model.UserInfo;
import org.apache.ibatis.annotations.Mapper;import java.util.List;
@Mapper
public interface UserInfoXMLMapper {List<UserInfo> selectAll();
}

注意

加注解@mapper,不添加会报错

 

在xml文件添加代码

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.demo.mapper.UserInfoXMLMapper"><select id="selectAll" resultType="com.example.demo.model.UserInfo">select* from userinfo</select>
</mapper>

注意

1.mapper标签中的namespace内容是java目录下的UserInfoXNMLMapper文件路径

2.select标签为自己编写的查询语句 ,其中id是UserInfoXNMLMapper中的方法名必须一模一样,resultType为返回数据的类型

3.只有在select才会需要resultType

 5.xml文件实现增删查改

①增

方法声明在UserInfoXNMLMapper文件中

Integer insert(UserInfo userInfo);

在UserInfoXNMLMapper.xml文件中实现,用insert标签

<insert id="insert" useGeneratedKeys="true" keyProperty="id">insert into userinfo (username, password, age, gender, phone)values(#{username},#{password},#{age},#{gender},#{phone})</insert>

注意

1.方法名和id一定要一样

2.useGeneratedKeys="true" keyProperty="id"自主获取id

3.如果出现重命名则需要对象应用 如userInfo.username

②删

 方法声明在UserInfoXNMLMapper文件中,根据id删除

Integer delete (int id);

在UserInfoXNMLMapper.xml文件中实现,用delete标签

 <delete id="delete">delete from userinfo where id=#{id}</delete>

③改

 方法声明在UserInfoXNMLMapper文件中,根据id

Integer update(int gender,int id);

在UserInfoXNMLMapper.xml文件中实现,用update标签

<update id="update">update userinfo set gender=#{gender} where id=#{id};</update>

 

相关文章:

MyBatis的xml实现

1.下载插件MyBatisX 2.添加依赖 <!--Mybatis 依赖包--><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.3.1</version></dependency><!--…...

dolphinscheduler任务莫名重跑

dolphinscheduler运行了一段时间&#xff0c;忽然发现一个流程下某个任务一直在自动重跑&#xff0c;把工作流删了&#xff0c;任务删了&#xff0c;下线等等&#xff0c;都不能阻止他重复的运行&#xff0c;每秒1次&#xff0c;真是见了鬼 1、把zookeeper停掉发现不再重跑了 …...

Modbus TCP/RTU协议转PROFINET协议网关

...

Caché for UNIX®, Linux及macOS的安装及配置

本文介绍在UNIX、Linux或macOS系统上安装Cach的操作步骤。本文假设用户已熟悉UNIX、Linux和macOS目录结构、实用程序和命令。 本文包含如下主要部分: 1)Cach安装。 2)无人值守的Cach安装。 3)安装后任务。...

【书籍篇】Git 学习指南(一)基础概念及入门

Git 学习指南&#xff08;一&#xff09;基础概念及入门 一. 基本概念1.1 分布式版本控制1.1.1 集中式版本控制系统1.1.2 分布式版本控制系统1.1.3 特型版本库 1.2 版本库&#xff0c;分布式工作的基础所在1.2.1 散列值 1.3 分支的创建与合并1.3.1 分支的其他操作 二. 入门2.1 …...

JWT知识点

什么是JWT Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准&#xff08;(RFC 7519).该token被设计为紧凑且安全的&#xff0c;特别适用于分布式站点的单点登录&#xff08;SSO&#xff09;场景。JWT的声明一般被用来在身份提供者和服务提…...

UDP接收报文函数recvfrom和UDP发送报文函数sendto

#include <sys/socket.h> ssize_t recvfrom(int sockfd, void *buff, size_t nbytes, int flags, struct sockaddr *from, socklen_t *addrlen); sockfd、buff 和 nbytes 是前三个参数。sockfd 是本地创建的套接字描述符&#xff0c;buff 指向本地的缓存&#xff0c;nbyt…...

Redisson 分布式锁实战应用解析

文章目录 前言一、Redisson介绍二、Redisson的使用1.1 引入依赖1.2 编写配置1.3 示例测试_011.4 示例测试_02 三、Redisson源码分析2.1 加锁源码2.2 看门狗机制 前言 分布式锁主要是解决分布式系统下数据一致性的问题。在单机的环境下&#xff0c;应用是在同一进程下的&#x…...

【机器学习】对比学习(contrastive learning)

对比学习是一种机器学习技术&#xff0c;算法学习区分相似和不相似的数据点。对比学习的目标是学习数据的表示&#xff0c;以捕捉不同数据点之间的基本结构和关系。 在对比学习中&#xff0c;算法被训练最大化相似数据点之间的相似度&#xff0c;并最小化不相似数据点之间的相似…...

开源和闭源的优劣势比较

开源与闭源软件之争一直是技术领域一个备受关注的话题&#xff0c;而在近期特斯拉CEO马斯克的表态中&#xff0c;关于开源的讨论更是引发了广泛的关注。以下是一些关于开源和闭源的优劣势以及对未来大模型发展的一些见解&#xff1a; 开源软件的优势&#xff1a; 创新与合作&a…...

html手势密码解锁插件(附源码)

文章目录 1.设计来源1.1 界面效果 2.效果和源码2.1 动态效果2.2 源代码 源码下载 作者&#xff1a;xcLeigh 文章地址&#xff1a;https://blog.csdn.net/weixin_43151418/article/details/134534785 html手势密码解锁插件(附源码)&#xff0c;仿手机手势密码&#xff0c;拖动九…...

Jetson JetPack-5.1.2-L4T-R35.4.1 修复deskew algorithm的问题

1. 前言 官方Orin Nano开发套件 版本: JetPack 5.1.2 2. 问题描述 使用的是带有Orin Nano EVK的GMSL相机,但我无法看到MIPI帧。 这里是媒体设备信息: Media controller API version 5.10.120Media device information ------------------------ driver tegra-…...

Doris的分区表和分桶表

1 列定义 以AGGREGATE KEY数据模型为例进行说明。更多数据模型参阅Doris数据模型。 列的基本类型,可以通过在mysql-client中执行HELP CREATE TABLE; 查看。 AGGREGATE KEY数据模型中,所有没有指定聚合方式(SUM、REPLACE、MAX、MIN)的列视为Key列。而其余则为Value列。 定义…...

华为HCIE技术(HCIP、HCIE)汇总

我所在的岗位是网络运维&#xff0c;路由与交换用的比较多&#xff0c;外网技术比较少。所以把经常用的写的比较详细。大家多多包涵。 理论部分 网络基础&#xff1a;ISO网络七层模型 交换机部分 首次Console口登陆配置Telnet访问 VLAN VLAN的介绍、单交换机vlan划分实验…...

React结合antd5实现整个表格编辑

通过react hooks 结合antd的table实现整个表格新增编辑。 引入组件依赖 import React, { useState } from react; import { Table, InputNumber, Button, Space, Input } from antd;定义数据 const originData [{ key: 1, name: 白银会员, value: 0, equity: 0, reward: 0…...

【C++进阶之路】第八篇:智能指针

文章目录 一、为什么需要智能指针&#xff1f;二、内存泄漏1.什么是内存泄漏&#xff0c;内存泄漏的危害2.内存泄漏分类&#xff08;了解&#xff09;3.如何检测内存泄漏&#xff08;了解&#xff09;4.如何避免内存泄漏 三、智能指针的使用及原理1.RAII2.智能指针的原理3.std:…...

保护服务器免受攻击:解析攻击情境与解决之道

在数字化时代&#xff0c;服务器安全问题日益突出&#xff0c;因为它们是企业和个人网络活动的核心。服务器被攻击可能引发一系列问题&#xff0c;理解攻击的不同情境以及采取相应的解决方法变得至关重要。 DDoS 攻击&#xff08;分布式拒绝服务攻击&#xff09; 情境&#xff…...

Python 获取两个数组中各个坐标点对之间最短的欧氏距离

Python 获取两个数组中各个坐标点对之间最短的欧氏距离 代码如下: import numpy as np from scipy import spatialxy1 = np.array([[243, 3173],[525, 2997]]...

假ArrayList导致的线上事故......

假ArrayList导致的线上事故… 线上事故回顾 晚饭时&#xff0c;当我正沉迷于排骨煲肉质鲜嫩&#xff0c;汤汁浓郁时&#xff0c;产研沟通群内发出一条消息&#xff0c;显示用户存在可用劵&#xff0c;但进去劵列表却什么也没有&#xff0c;并附含了一个视频。于是我一边吃了排…...

K8S精进之路-控制器Deployment-(1)

在K8S中&#xff0c;最小运行单位为POD,它是一个逻辑概念&#xff0c;其实是一组共享了某些资源的容器组。POD是能运行多个容器的&#xff0c;Pod 里的所有容器&#xff0c;共享的是同一个 Network Namespace&#xff0c;并且可以声明共享同一个 Volume。在POD中能够hold住网络…...

手把手调试:用CANoe/CANalyzer抓包分析UDS 10服务的完整会话生命周期

手把手调试&#xff1a;用CANoe/CANalyzer抓包分析UDS 10服务的完整会话生命周期 在汽车电子控制单元&#xff08;ECU&#xff09;的开发和测试中&#xff0c;诊断协议的理解和应用是工程师必备的核心技能之一。UDS&#xff08;Unified Diagnostic Services&#xff09;协议作为…...

软件定义无线电与认知无线电技术解析及应用

1. 无线通信技术演进&#xff1a;从硬件定义到软件智能 三十多年前&#xff0c;当我第一次以初级射频工程师的身份踏入实验室时&#xff0c;我们还在使用分立晶体管搭建电路&#xff0c;一个简单的接收机可能需要花费数周时间手工调试。如今&#xff0c;我的智能手机里集成了数…...

Python办公自动化实战:结合ChatGPT实现邮件、PPT、Excel与PDF批量处理

1. 项目概述&#xff1a;用Python与ChatGPT解放你的办公桌如果你每天的工作中&#xff0c;有超过一半的时间都在和Outlook、Excel、PowerPoint、PDF这些“老朋友”打交道&#xff0c;重复着复制粘贴、格式调整、邮件群发、报告生成的机械劳动&#xff0c;那么这篇文章就是为你准…...

P1227 完美的对称【洛谷算法习题】

P1227 完美的对称 网页链接 P1227 完美的对称 题目描述 在峰会期间&#xff0c;必须使用许多保镖保卫参加会议的各国代表。代表们除了由他自己的随身保镖保护外&#xff0c;组委会还指派了一些其他的特工和阻击手保护他们。为了使他们的工作卓有成效&#xff0c;使被保卫的…...

SAFE框架:提升大语言模型响应稳定性的智能路由方案

1. 项目背景与核心价值 上周在部署一个对话系统时&#xff0c;我遇到了大语言模型&#xff08;LLM&#xff09;响应不稳定这个典型问题——同样的输入有时能得到完美回答&#xff0c;有时却返回无意义内容。经过反复测试&#xff0c;最终通过SAFE框架将响应稳定性提升了87%。这…...

在Hermes Agent项目中接入自定义大模型提供方

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 在Hermes Agent项目中接入自定义大模型提供方 基础教程类&#xff0c;指导正在使用Hermes Agent框架的开发者如何集成Taotoken服务…...

我们到底在为安全运维服务买单什么?——国内厂商核心能力拆解

在网络安全行业&#xff0c;有一个常年存在的悖论&#xff1a;企业花大价钱采购了各类安全设备&#xff0c;构建了看似固若金汤的防御体系&#xff0c;但安全事件依然频发&#xff1b;于是&#xff0c;企业又不得不掏出一笔预算购买“安全运维服务”。很多管理者在签字时都会产…...

Spring的三级缓存机制详解及深度剖析其必要性

一、Spring为什么需要三级缓存源码剖析 Spring采用三级缓存机制来处理单例Bean的循环依赖&#xff0c;主要是为了解决一个核心难题&#xff1a;当循环依赖遇上AOP&#xff08;面向切面编程&#xff09;时&#xff0c;如何保证最终注入到其他Bean的&#xff0c;是且仅是唯一的代…...

DouyinLiveRecorder:40+平台直播录制终极解决方案,告别频繁中断的技术指南

DouyinLiveRecorder&#xff1a;40平台直播录制终极解决方案&#xff0c;告别频繁中断的技术指南 【免费下载链接】DouyinLiveRecorder 可循环值守和多人录制的直播录制软件&#xff0c;支持抖音、TikTok、Youtube、快手、虎牙、斗鱼、B站、小红书、pandatv、sooplive、flextv、…...

终极GitHub加速插件完整指南:三步搞定下载速度飙升100倍!

终极GitHub加速插件完整指南&#xff1a;三步搞定下载速度飙升100倍&#xff01; 【免费下载链接】Fast-GitHub 国内Github下载很慢&#xff0c;用上了这个插件后&#xff0c;下载速度嗖嗖嗖的~&#xff01; 项目地址: https://gitcode.com/gh_mirrors/fa/Fast-GitHub 还…...