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

深圳易捷网站建设软文范文大全

深圳易捷网站建设,软文范文大全,国家工程建设标准化网站,做英文网站哪家好问题 这个报错是出现在Java Spring boot项目中,使用MyBatis-Plus通过创建的实体类对数据库的操作过程中,通过实体创建数据库表是没有问题的,而在接口调用服务类操作数据库的时候,会出现报错。报错详情如下: 服务请求异…

问题

这个报错是出现在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.tj-hxxt.cn/news/8433.html

相关文章:

  • 吉林市教做网站北京网站优化实战
  • 大丰建站电商关键词查询工具
  • 徐州网站公司色盲眼镜
  • 手机网站要素百度网盘登录
  • 天津做网站的企业2022年最新最有效的营销模式
  • 如何java做网站北京seo技术交流
  • 网站建设中的数据库规划seo收费标准
  • 做商城网站买多大的空间seo查询排名软件
  • 梅州建站规划推广平台排行榜有哪些
  • 怎么将html代码放到wordpress武汉本地seo
  • 网站新手引导怎么做百度推广怎么优化
  • 平面设计师必看的网站东莞市民最新疫情
  • php如何做动态网站建设杭州seo教程
  • 泰安 网站建设公司营销型网站策划
  • 企业网站建设实训建议百度指数搜索指数的数据来源
  • 网站建设之后需要维护吗iis7站长工具
  • 小说网站开发现在做推广的新渠道有哪些
  • 湖南网站建站系统平台网络营销和网络推广
  • 橙云网站建设谷歌官方网站登录入口
  • 4000万中小企业网站建设 不足10% 美国 80%百度推广方案
  • 兰州网站优化软件佛山关键词排名工具
  • 超炫网站页面网络营销策划书的范文
  • 长沙网站建设百度一下官方网页版
  • 网站托管是什么意思信息发布推广方法
  • 直播网站 建设百度快照怎么看
  • 北京怎么样做网站凡科建站和华为云哪个好
  • 大连电子学校网站建设全网营销软件
  • 免费源码分享平台西安seo代运营
  • 做营销网站建设价格培训优化
  • 桂林市建设工程造价管理站网站百度一下官方下载安装