第九章MyBatis的技巧

${}和#{}的区别

  • #{}给sql语句的占位符传值
  • ${}直接将值拼接到sql语句上,存在sql注入的现象

什么时候用${}

需要先对sql语句拼接,然后再编译。

  • 字符串排序字段
  • 向SQL语句中拼接表名。比如根据日期生成日志表

批量删除

复制代码
delete from car where in(${ids})

模糊查询

复制代码
select from car where name concat('%',#{name},'%');

select from car where name '%${name}%'

select from car where name "%"#{name}"%"

别名

在MyBatis中配置。type为被取的名字,alias为取成什么

别名不区分大小写,命名空间不可以取别名

复制代码
<typeAliases>
    <typeAlias type="com.example.webapplication.pojo.Car" alias="abc"></typeAlias>
</typeAliases>

如果省略alias。别名默认为类的简名

下述例子中,别名为car/CAR

复制代码
<typeAliases>
    <typeAlias type="com.example.webapplication.pojo.Car" ></typeAlias>
</typeAliases>

如果类太多会写很多typeAlias标签

使用package可以将包下所有类起别名

复制代码
<typeAliases>
    <package name="com.example.webapplication.pojo"/>
</typeAliases>

Mapper

mappers下的mapper有3个属性可以选,主要为了找到sql的配置文件

  • resource从类的根路径下开始找
  • url绝对路径
  • class值为接口的全限定名,并且对应的xml必须与接口保存同一文件下名字也要相同

如果配置文件太多需要写的标签太多可以用package来指定包其他用法与class类似

复制代码
<mappers>
   <package name="com.example.webapplication.Mapper"/>
</mappers>

插入数据时自动获取数据的主键

  • useGeneratedKeys表示使用自动生成的主键值

  • keyProperty表示将主键值赋值给对象的id属性

    <insert id="insert" useGeneratedKeys="true" keyProperty="id"/>
相关推荐
2401_8384725124 分钟前
自定义操作符重载指南
开发语言·c++·算法
Leo6553524 分钟前
easyExcel 的动态列导出把文本转为数值格式,可以进行函数计算
java
v_for_van26 分钟前
单片机内存分配管理笔记
开发语言·c++·笔记·vscode·stm32·单片机·嵌入式硬件
鹿角片ljp29 分钟前
力扣136.只出现一次的数字-异或和HashMap
java·数据结构·算法·leetcode
W_a_i_T29 分钟前
【Coding日记】菜鸟编程C语言100例——第三题⚠️
c语言·开发语言·经验分享·算法·菜鸟编程
weixin_4521595532 分钟前
多协议网络库设计
开发语言·c++·算法
十五年专注C++开发32 分钟前
浅谈C++插件机制的设计要点以及实现方案
开发语言·c++·系统架构·插件机制
Hello World . .32 分钟前
C语言printf: VT100 终端控制码
c语言·开发语言·jvm
爱装代码的小瓶子33 分钟前
【C++与Linux基础】文件篇 -语言特性上的文件操作
linux·开发语言·c++
weixin_3954489135 分钟前
下位机&yolov11输出
java·服务器·前端