尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

key,value,isDef关键字的隐藏bug

key,value,isDef关键字的隐藏bug
📅 发布时间:2026/6/20 2:17:06

key,value,isDef关键字的隐藏bug

前言:
有个老师傅创建表用关键字,返回的response用特殊字符导致的问题

1 ,表创建用到了关键字

表如下:

CREATE TABLE `system_xxx_config`(`id` BIGINT NOTNULLCOMMENT'主键'PRIMARY KEY,`key`varchar(255)NOTNULLCOMMENT'配置文件key',`value`varchar(512)NOTNULLCOMMENT'配置文件value',...)COMMENT'xxx配置表'COLLATE=utf8mb4_unicode_ci;

正常我们写接口,使用BaseMapper集成 MyBatis实现简单的crud
代码如下

@Override public R<GlobalConfigVo>queryxxxConfigVoByKey(String key){GlobalConfigVo configVo=newGlobalConfigVo();GlobalConfigDO configDO=globalConfigMapper.selectOne(GlobalConfigDO::getKey,key);if(Objects.isNull(configDO)){returnCommonResult.success(configVo);}BeanUtils.copyProperties(configDO,configVo);returnCommonResult.success(configVo);}

但是就是报

SQL: SELECT id, key, value, deleted, create_time, update_time, creator, updater, x_channel, x_platform FROM system_global_config WHERE deleted = 0 AND (key= ?)

Cause: java.sql.SQLSyntaxErrorException: 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 ‘key, value, deleted, create_time, update_time, creator, xx,’ at line 1

; bad SQL grammar []
2025-12-23 16:53:55.138 | ERROR 7 | http-nio-48091-exec-7 [TID: N/A] | [USER_ID: 1950821235660029954] [USER_IP: 42.99.63.70] [X_CHANNEL: zp] [X_PLATFORM: middleAndroid] [DEVICE_ID: 123321] [VERSION: 1.1.0.0.1] [REQUEST_ID: 2f9275a4-c754-4122xxxa902-93c241c54947] | c.h.f.w.c.h.
简单的说就是 使用key 、value 关键字,mybatis自动生成的sql用不了,会报错。

尝试

@Override public R<GlobalxxConfigVo>queryGlobalxxxConfigVoByKey(String key){LambdaQueryWrapper<GlobalxxConfigDO>wrapper=new LambdaQueryWrapper<>();wrapper.eq(GlobalxxxConfigDO::getKey,key).eq(GlobalxxConfigDO::getDeleted,0);GlobalxxConfigDO configDO=globalxxConfigMapper.selectOne(wrapper);GlobalxxConfigVo configVo=newGlobalxxxConfigVo();BeanUtils.copyProperties(configDO,configVo);returnR.success(configVo);}

还是报错误,
最终写
sql 做mapper映射解决bug
select xxx from xxx where xxx;

2、response返回值封装触发关键字 isDef

{"code":220,"data":[{"config":"1024x","isDef":true},{"config":"2048x","isDef":false}],"msg":""}

正常封装对象:

@Data @NoArgsConstructor @AllArgsConstructor public class GlobalxxxConfigVo{private String config;private boolean isDef;}

写好后返回是:

{"code":220,"data":[{"config":"1024x","def":true},{"config":"2048x","def":false}],"msg":""}

查询原因是
问题分析:
在Java中,使用Lombok的@Data注解时,对于布尔类型的字段,Lombok生成的getter方法命名规则为:如果是基本类型boolean,字段名为isDef,则生成的getter方法为isDef(),setter方法为setDef(boolean)。但是,在序列化为JSON时,Jackson等序列化框架默认使用getter方法来确定字段名。对于布尔类型,可能会产生混淆。

字段名为isDef,Lombok生成的getter方法为isDef(),setter为setDef(boolean)。序列化框架可能会将字段名解析为def(因为getter方法名为isDef,去掉is后,首字母小写为def),所以返回的JSON中出现了def字段。

解决方案:

使用Jackson的@JsonProperty注解,指定序列化时的字段名。

@Data @NoArgsConstructor @AllArgsConstructor public class GlobalxxxConfigVo{/** * 视频彩铃分配率 */private String config;/** * 如果匹配默认的就是true 没有匹配到就是false */@JsonProperty("isDef")private boolean isDef;}

都是师傅学到了。。。。

喜欢我的文章记得点个在看,或者点赞,持续更新中ing…

相关新闻

  • GPT-SoVITS语音合成延迟优化:实时应用可行性探讨
  • RevokeMsgPatcher终极解析:彻底告别消息撤回烦恼
  • Yocto项目初期必备工具链部署完整示例

最新新闻

  • 从TTL到485:深入解析差分信号转换电路的设计要点与实战应用
  • 杭州GEO优化公司2026年6月Top5:选型疑问与避坑全解 - GEO优化
  • 2026年最新武汉光谷科技职业技术学校联系方式及招生办电话号码 - 武汉中职最新信息发布
  • 揭秘Mac鼠标滚轮终极优化:让外接鼠标拥有触控板般的丝滑体验
  • MC9RS08KA2内部时钟与定时器深度解析:从原理到低功耗设计实战
  • 2026玉林本地人必选防水补漏检测维修公司靠谱服务商TOP5推荐:房屋渗漏水检测维修/卫生间/厨房/天花板/阳台/外墙渗漏水检测补漏维修-暗管漏水检测专业仪器精准定位漏水点 - 即刻修防水

日新闻

  • 信任的进化:技术实现详解——如何用JavaScript构建博弈论模拟器
  • Terrakube自定义工作流:如何集成OPA、Infracost等工具扩展IaC能力
  • grunt-concurrent快速入门:5分钟学会并行运行Grunt任务

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号