Spring boot注解开发mybatis

数据库连接配置,在resources目录下的application.propertis文件配置:

#数据库连接配置
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/db1
spring.datasource.username=root
spring.datasource.password=qw123456
#指定mybatis日志的输出位置,输出控制台
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

在sql接口使用注解@Mapper。作用就是将接口生成一个动态代理类。这个注解就是用来映射mapper.xml文件的。

如果mapper接口方法形参只有一个普通类型的参数,#{...}里面的属性名可以随便写。

参数占位符:

        #{...}:执行sql语句时,会将#{...}替换为?,生成预编译sql,会自动设置参数值。使用时机:参数传递,都使用#{...}。

                预编译sql:性能更高,更加安全(防止sql注入)

        ${...}:拼接sql。直接将参数拼接在sql语句中,存在sql注入问题。使用时机:如果对表名、列表进行动态设置时使用。

数据封装:

        mybatis要求列名与属性名一直才能自动封装数据,若列名与属性名不一致,则需要手动映射。

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

@Select("select id, username, password, name, gender, image, job, entrydate," +" dept_id deptId, create_time createTime, update_time updateTime " +"from emp where id=#{id}")
public Emp selectById(int id);

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

@Select("select * from emp where id=#{id}")
@Results({@Result(column="dept_id",property="deptId"),@Result(column = "create_time",property="createTime"),@Result(column = "update_time",property="updateTime")
})
public Emp selectById(int id);

        3、对于字段名与属性名符合驼峰命名规则,mybatis会自动通过驼峰命名规则映射。

#开启驼峰命名自动映射
mybatis.configuration.map-underscore-to-camel-case=true
@Mapper
public interface EmpMapper {@Delete("delete from emp where id=#{id}")public int deleteForId(int id);//    将自动生成的主键值返回,赋值给emp的id对象@Options(keyProperty = "id",useGeneratedKeys = true)@Insert("insert into emp(username, password, name, gender, image, job, entrydate, dept_id, create_time, update_time) VALUES" +"(#{username},#{password},#{name}, #{gender}, #{image}, #{job}, #{entrydate}, #{deptId}, #{createTime}, #{updateTime})")public int insert(Emp emp);
}

在一个字段内传递参数时可使用concat来进行连接。比如:'%#{name}%'是不可用的,进行预编译时会将替换的?当成字符串来处理,无法传参,可使用concat('%',#{name},'%')来将字符串进行拼接。

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

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

相关文章

cdp集群Hbase组件HRegionServer服务停止原因以及排查

前言:重启集群后某一节点HRegionServer服务停止,重启前所有服务均正常 去查看日志: 日志报错 ERROR HRegionServer Master rejected startup because clock is out of sync org.apache.hadoop.hbase.ClockOutOfSyncException: org.apache.h…

Spark-Scala语言实战(17)

我带着大家一起来到Linux集群环境下,学习我们的spark。想了解的朋友可以查看这篇文章。同时,希望我的文章能帮助到你,如果觉得我的文章写的不错,请留下你宝贵的点赞,谢谢。 Spark-Scala语言实战(16&#x…

linux 基础命令docker及防火墙iptables详解

应用场景: web应用自动打包和发布 自动化测试,持续集成、发布 在服务环境中部署后台应用 搭建paaS平台 安装应用 apt install docker.io#kali中 配置docker源,文件位置/etc/docker/daemon.json { "registry-mirrors": [ "h…

机器学习和深度学习-- 李宏毅(笔记于个人理解)Day 21

Day 21 Self- Attention 选修部分 ​ 学完自适应 再回来看看 Sequence Labling 假如我们现在有一个需要读完全部句子才能解的问题, 那么red window 就需要变得是最大的(最长的句子); 其实这里大家有没有想过,这个玩意…

死磕GMSSL通信-java/Netty系列(二)

死磕GMSSL通信-java/Netty系列(二) 在上一篇文章中,我们探讨了如何利用C/C++实现国密通信。而本文将聚焦于Java环境下,特别是基于Netty框架,如何实现与国密系统的安全通信。为了确保新项目遵循最新的国密标准,我们将优先推荐使用GB/T 38636-2020(TLCP)协议。对于Java开…

45、二叉树-二叉树的右视图

思路 层序遍历 从左向右遍历每一层取最后一个数&#xff0c;代码如下&#xff1a; public List<Integer> rightSideView(TreeNode root) {if (rootnull){return new ArrayList<>();}Queue<TreeNode> queue new LinkedList<>();List<Integer> …

一例Mozi僵尸网络的挖矿蠕虫分析(workminer)

概述 这是一个Linux平台的挖矿蠕虫&#xff0c;使用了go和C混合编译而成&#xff0c;主要通过爆破SSH口令进行传播&#xff0c;属于Mozi僵尸网络。其中GO代码负责SSH相关的爆破传播&#xff0c;以及对Config的处理&#xff0c;C代码则负责处理加入Mozi P2P网络&#xff0c;拉取…

java登陆centos切换root用户,sftp上传jar包部署更新

我们的内网服务器每次更新前后端包时&#xff0c;都要先登陆一个普通xunjian帐号&#xff0c;再切换成root输入密码&#xff0c;上传包后再用命令更新&#xff0c;操作有点麻烦&#xff0c;所以用JSch写了一个工具类来实现密码输入和用户的切换以及项目包的上传和更新&#xff…

js中let和var的区别

在JavaScript中&#xff0c;var、let和const都用于声明变量&#xff0c;但它们之间存在一些重要的区别。特别是let和var之间的区别&#xff0c;我们可以概括为以下几点&#xff1a; 作用域&#xff08;Scope&#xff09;&#xff1a;var有函数作用域或全局作用域&#xff0c;而…

SpringBoot项目中整合MinIO

在Spring Boot项目中整合MinIO&#xff0c;可以按照以下步骤进行操作&#xff1a; 1. 添加MinIO依赖 <dependency><groupId>io.minio</groupId><artifactId>minio</artifactId><version>8.5.9</version></dependency>2. 配置…

牛客 D 无限的韵律源点 (对顶堆+滑动窗口)

牛客 D 无限的韵律源点 &#xff08;对顶堆滑动窗口&#xff09; 题目链接 思路 本题的重点在于 recent best部分&#xff0c;即指定下标和指定长度的区间 k 最大值&#xff0c;这实际上是区间 k 最值的***版。因此可以选择主席树&#xff0c;划分树等数据结构直接维护。由于…

mybatis的使用技巧8——联合查询union和union all的区别和用法

在实际项目开发中&#xff0c;会经常联合查询结构相似的多张数据表&#xff0c;使用union关键字就只需要一次sql操作&#xff0c;而无需执行多次查询并通过代码逻辑合并处理&#xff0c;减少了大量繁琐的操作&#xff0c;最重要的是还能通过可选的all关键字筛选重复的数据。 1…

Python实现将文件夹下的所有pdf文件合并成一个pdf文件,并用文件夹名字命名

Python实现将文件夹下的所有pdf文件合并成一个pdf文件&#xff0c;并用文件夹名字命名 # -*- coding: utf-8 -*-import os import PyPDF2def merge_pdfs(folder_path):# 获取文件夹名称folder_name os.path.basename(folder_path)# 搜索文件夹内的所有PDF文件pdf_files [f fo…

chatgpt免费使用网站

在人工智能的浪潮中&#xff0c;OpenAI的ChatGPT作为一款前沿的语言处理工具&#xff0c;已经引起了广泛的关注和讨论。 ChatGPT以其卓越的语言理解和生成能力&#xff0c;为用户提供了多样化的应用场景&#xff0c;从日常对话、编程辅助到内容创作等。然而&#xff0c;对于许…

RAID10如何创建?RAID10做法详细说明

RAID10创建步骤主要有7步&#xff1a;1.硬件准备&#xff1b;2.配置RAID卡或存储设备&#xff1b;3.选择RAID级别&#xff1b;4.添加硬盘到RAID 10组&#xff1b;5.添加硬盘到RAID 10组&#xff1b;6.保存并退出配置&#xff1b;7. 初始化RAID 10阵列。 RAID 10&#xff0c;也…

鸿蒙OpenHarmony【搭建Ubuntu环境】

搭建Ubuntu环境 在嵌入式开发中&#xff0c;很多开发者习惯于使用Windows进行代码的编辑&#xff0c;比如使用Windows的Visual Studio Code进行OpenHarmony代码的开发。但当前阶段&#xff0c;大部分的开发板源码还不支持在Windows环境下进行编译&#xff0c;如Hi3861、Hi3516…

MySQL文件目录结构:表在文件系统中的表示

以下内容基于Linux系统&#xff0c;MySQL的 /var/lib/mysql/ 目录下的数据文件 &#x1f496; Innodb 引擎 MySQL 5.7 MySQL 8.0 &#x1f31f; 总结 Innodb 是聚簇索引&#xff0c;索引及数据&#xff0c;数据即索引&#xff0c;所以数据和索引是存储在同一个文件中的 MyS…

OpenHarmony网络协议通信—libevent [GN编译] - 事件通知库

libevent主要是用C语言实现了事件通知的功能 下载安装 直接在OpenHarmony-SIG仓中搜索libevent并下载。 使用说明 以OpenHarmony 3.1 Beta的rk3568版本为例 库代码存放路径&#xff1a;./third_party/libevent 修改添加依赖的编译脚本 在/developtools/bytrace_standard/…

C#面:.NET默认的委托类型有哪几种?

C# .NET默认的委托类型有以下几种&#xff1a; Action&#xff1a;Action 是一个泛型委托类型&#xff0c;它可以接受0到16个参数&#xff0c;并且没有返回值。例如&#xff0c;Action<int> 表示一个接受一个int类型参数的委托。Func&#xff1a;Func 也是一个泛型委托类…

el-table 表格从下往上滚动,触底自动请求新数据

关键点&#xff1a; 1、 el-table 需要设置高度 height&#xff1b; 2、el-table 外层盒子需要设置一个高度&#xff0c;并且设置 overflow&#xff1a;hidden&#xff1b; 3、获取 el-table 的 bodyWrapper&#xff1a;divData divData.scrollTop divData.clientHeight 1 &g…