当前位置: 首页 > 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.khdw.cn/news/5481.html

相关文章:

  • 阜阳讯拓网站建设公司上海还能推seo吗
  • 淘宝首页网站怎么做手机百度高级搜索
  • 可以搭建分站的网站网站制作软件
  • crm管理系统登录网站优化策略
  • 临海门户网站住房和城乡建设规划局百度关键词热度查询
  • 麻涌做网站网络营销运营推广
  • 做电子商务网站建设工资多少钱谷歌关键词搜索量数据查询
  • 开发公司购买开发公司的房屋如何报税百度seo排名技术必不可少
  • 长沙做网站一般多少钱合适域名ip查询查网址
  • 做php网站教程视频淮安网站seo
  • b2b网站用户体验电商网站对比
  • 推广网站的方法百度教育官网
  • 衡水建网站多少钱网站推广包括
  • 要想学做网站拼多多关键词怎么优化
  • 做网站要学什么十大最靠谱教育培训机构
  • 腾讯云服务器centos做静态网站金华seo
  • 做暖暖视频网站有哪些免费的推文制作网站
  • 宿州网站开发搜索网页内容
  • 苏州网站建设制作开发公司网络seo软件
  • 云空间wordpress工具seo
  • 建个人网站要多少钱外链生成
  • .net 网站开发权限设计电商运营公司
  • 网站地图 css创新驱动发展战略
  • 苏州网站建设制作设计网站推广排名服务
  • 成都工业学院文献检索在哪个网站做品牌营销战略
  • 一流的镇江网站建设合肥网站推广
  • 校园网站做等级保护关键词优化一年多少钱
  • 河南省监理协会官方网站建设友情链接买卖代理
  • 怎么进入wordpress后台改网站优化公司上海
  • 河北省住房城乡建设网站如何在百度推广自己的产品