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

Java 使用MyBatis-Plus数据操作关键字冲突报错You have an error in your SQL syntax问题

问题

这个报错是出现在Java Spring boot项目中,使用MyBatis-Plus通过创建的实体类对数据库的操作过程中,通过实体创建数据库表是没有问题的,而在接口调用服务类操作数据库的时候,会出现报错。报错详情如下:

服务请求异常:org.springframework.jdbc.BadSqlGrammarException:
com..server.mapper.UsageMapper.insert (batch index #1) failed.
Cause: java.sql.BatchUpdateException: You have an error in your SQL
syntax; check the manual that corresponds to your MySQL server version
for the right syntax to use near 'usage,…
… create_time,
update_time) VALUES (1854720160046714882, 18547201’ at line 1; bad
SQL grammar []; nested exception is java.sql.BatchUpdateException: You
have an error in your SQL syntax; check the manual that corresponds to
your MySQL server version for the right syntax to use near 'usage,
… , create_time, update_time) VALUES (1854720160046714882,
18547201’ at line 1.
在这里插入图片描述

其中的实体类如下:

@Data
@TableName(autoResultMap = true)
@TableComment("用量信息")
@ApiModel(value = "用量信息")
public class GoodsUsage {
    @ApiModelProperty(value = "id")
    @Column(comment = "id")
    private Long id;
    
    @ApiModelProperty(value = "用量")
    @Column(comment = "用量")
    private BigDecimal usage;

    @ApiModelProperty("创建时间")
    @Column(comment = "创建时间")

    private LocalDateTime createTime;
    @ApiModelProperty("更新时间")
    @Column(comment = "更新时间")
    private LocalDateTime updateTime;
}

报错的调用处理是批量保存数据记录:

this.saveBatch(usages);

解决方法

看到报错问题,以为是关键字引起数据库操作问题,后来发现MyBatis-Plus已经根据实体创建出了数据库表:
在这里插入图片描述

后续没有照着这个方向调试,而是以为MyBatis-Plus 的LambdaQueryWrapper 表达式所生成的SQL语句有问题,排查了很久,也没有发现问题,不过将控制台选择复制打印的params的sql语句复制过去存在同样的报错,最后发现是usage字段名和MySQL的Usage权限重名了,也就是关键字冲突,将usage字段重命名为其他可用的名称即可修复。

以下为其他解决参考:
注意尽量避免使用关键字作为表名或者字段名,如果一定要用关键字作为字段名,在SQL处理时,用单引号将名称括起来(‘usage’); MyBatis-Plus 的关键字处理,可以使用 @TableName 和 @TableField 注解来处理关键字,这样 MyBatis-Plus 在构建 SQL 时会使用单引号‘’来包围列名,从而避免了关键字冲突。
可以使用如下代码获取所有保留关键字:

import com.baomidou.mybatisplus.core.toolkit.StringPool;
import com.baomidou.mybatisplus.core.toolkit.SqlReservedWords;

String keywords = String.join(StringPool.COMMA, SqlReservedWords.KEYWORDS);
System.out.println("保留关键字: " + keywords);

http://www.kler.cn/a/395698.html

相关文章:

  • 常用在汽车PKE无钥匙进入系统的高度集成SOC芯片:CSM2433
  • 虎扑APP数据采集:JavaScript与AJAX的结合使用
  • 【SpringBoot】20 同步调用、异步调用、异步回调
  • HarmonyOS本地存储-Preferences(用户首选项)的使用
  • 试编写算法将单链表就地逆置(默认是带头节 点,如果是不带头节点地逆置呢?)
  • C++ —— 哈希详解 - 开散列与闭散列
  • linux逻辑卷练习
  • Mybatis官方生成器使用示例
  • 【电脑】解决DiskGenius调整分区大小时报错“文件使用的簇被标记为空闲或与其它文件有交叉”
  • 2023 年 3 月青少年软编等考 C 语言二级真题解析
  • 后端总指挥---文件接口
  • 坚持燃油新能源双赛道发力,MG ES5MG7 2025款亮相广州车展
  • Ascend C算子性能优化实用技巧05——API使用优化
  • [Python学习日记-67] 封装
  • 【快速上手】Kafka-Eagle 监控的安装部署
  • 蓝桥杯每日真题 - 第13天
  • YOLO系列基础(七)从数据增强到图像线性变换
  • 常见区块链公链的TPS是多少
  • MYSQL- 展示事件信息 EVENTS 语句(十八)
  • 036集——查询CAD图元属性字段信息:窗体显示(CAD—C#二次开发入门)
  • Jmeter中的前置处理器(一)
  • Ubuntu上搭建Flink Standalone集群
  • 虚拟机 | centos Stream 9 安装流程以及finalshell连接
  • 数字图像处理(c++ opencv):彩色图像处理-彩色基础与彩色模型
  • Android 6年经验面试总结 2024.11.15
  • 【开源项目】数字孪生仓储~经典开源项目数字孪生智慧仓储——开源工程及源码