【BUG合集】(一)①数据库存1/0,请求结果返回true和false;②sql查数据库能查,但mybatis查为空;③data64图片存储为异常;

news2025/1/22 21:01:09

前言

最近,在工作上接手的任务中,各种 bug 问题出现,在解决的同时也可以记录一下。因此,觉得可以出个记录 bug 合集。方便后来者碰到类似情况,可以作为一个参考进行解决。

文章题目就包含当前文章内容中所遇到的三个 bug…

【BUG】

1.【数据库存1/0,请求结果返回true和false】

【问题】
在做一个业务查询数据功能的时候,一开始查询结果的还一直疑惑,java 代码里 isRead 完全没找到转换为 boolean 类型的啊,数据库里明明也是整数型呢!还以为是在哪块有转换的,我没有找到。但是后来,新增的时候出现了代码报错。

代码报错:Cannot deserialize instance of `java.lang.Integer` out of VALUE_TRUE token at... through reference chain: com.anpai.xxx.xxx["isRead"]

【分析、发现与解决】(点击展开)

【原因】
检查半天后,才发现是数据库的锅,数据库!isRead字段是 tinyint 类型,且存储长度为1,则转为 java.lang.Boolean,否则转为 java.lang.Integer。巧了不是,刚好这张表涉及的isRead字段对应的数据类型就是 tinyint 且长度大小为 1
在这里插入图片描述

【如何发现】
琢磨半天,小问了一下同事小马才知道 mysql 数据库还会有这个机制!怪自己孤陋寡闻了。这太关键了吧!

【如何修复】:
把该字段的长度设置2就好了~(如下图) 或者把 tinyint类型改为int类型,只要破坏数据类型tinyint 且长度大小为 1 这两个条件之一,防止转换即可。

【小结】:
勤学多问,不要只在逻辑层,底层、数据库也可能会存在问题。

2.【sql查数据库能查,但mybatis查为空】

【问题】
一个业务中的一个查询,数据属于的对应的操作人、操作人的同部门和低部门的数据都可以看到。写好的 sql 语句(如下)在数据库能执行能获取到对应的操作人、操作人的同部门和低部门的数据也可看,但是在 mybatis 框架的 xml 执行只能获取到对应的操作人,获取不到操作人的同部门和低部门的数据

select * from t_book as b 
  where (
	   (b.created_user_id = "#{userId}" and b.dept) 
	or ( (SELECT GROUP_CONCAT(id SEPARATOR ',') as deptIds 
	         from t_dept 
	         where full_dept_id LIKE CONCAT('%',"#{deptId}",'%')) 
        LIKE CONCAT('%',b.dept_id,'%')
      )
  )

在这里插入图片描述

【分析、发现与解决】(点击展开)

【原因】
【未解决】: 一开始,以为代码中又有其他拦截器的权限拦截掉(执行的 sql 语句中加上部门 id 权限),但是 sql 语句已经一模一样在控制台中输出,但结果就是为空数据或不包含同级和下级的数据。

【个人揣测】: jdbc 框架不认可 or 后的 sql((集合)LIKE(数据),如下)

((SELECT GROUP_CONCAT(id SEPARATOR ',') as deptIds 
	         from t_dept 
	         where full_dept_id LIKE CONCAT('%',"#{deptId}",'%')) 
 LIKE CONCAT('%',b.dept_id,'%')
)

【如何发现】
接口返回的数据不对的时候发现的。

【如何修复】
我把这奇怪的问题,问向了同事小马。小马也很疑惑,同时也疑惑我的 sql 语句,听取了一下他的建议,用 find_in_set() 的方法去查询。结果居然可以了!

or 后的 sql(如下)

(FIND_IN_SET(b.dept_id, (SELECT GROUP_CONCAT(id SEPARATOR ',') as deptIds 
	         from t_dept 
	         where full_dept_id LIKE CONCAT('%',"#{deptId}",'%'))
)

完整 sql(如下)

select * from t_book as b 
  where (
	   (b.created_user_id = "#{userId}" and b.dept) 
	or ((SELECT GROUP_CONCAT(id SEPARATOR ',') as deptIds 
	         from t_dept 
	         where full_dept_id LIKE CONCAT('%',"#{deptId}",'%')) 
       LIKE CONCAT('%',b.dept_id,'%')
     )
)

【小结】
不要弄太复杂的 sql,多使用和熟悉 sql 提供的方法~

3.【data64图片存储为异常】

【问题】
一个富文本功能需要存储图片,做法是前端把图片进行data64转换然后传到后端存储到数据库里。但是进行有图片的富文本存了后,前端再请求展示出来,却是裂开的图片,不存在的。

(图左新增;图右查询

image.png     image.png

【分析、发现与解决】(点击展开)

【原因】
存到数据库的数据data64+号全变成 “ ”(空格)了。

【如何发现】
在检查后端也已经使用URLDecoder.decode() 进行转义了。才发现在前端就没传入进去,用在线文本比对工具 | 菜鸟工具对比一下才发现。前端传的时候就已经出错了,后端再怎么转义(把+号转对应的编码%2B)肯定都无济于事了。(图解发现过程)

对比数据(发现+号变成“ ”空格)

image.png

查找在哪变成了空格,发现是在网络传输层。(前端传参没问题,但是到后端变成了空格)

image.png

【如何修复】
基于前端传参没问题,但是到后端变成了空格的原因,那么在后端再怎么进行转义都是没有处理到点的。因此是在前端进行处理转义才对!

  // base64网络传输+号会变空格,全部替换为编码(%2B)
  var formContent = this.formContent;
  form.txt = formContent.txt.replaceAll("+","%2B"); 
  this.formContent = formContent;

【小结】
学习了网络传输层还会导致“+”变为“ ”(空格)。

总结

  1. 数据库的表里,字段为 tinyint 类型,且存储长度为1,会转为 java.lang.Boolean,否则转为 java.lang.Integer
  2. ① sql 查数据库能查,但 mybatis 查为空。LIKE 用法,JDBC 没有转移成功执行(集合)LIKE(数据)。(个人揣测)
    ② 不要弄太复杂的 sql,多使用和熟悉 sql 提供的方法。
  3. 网络传输层还会导致“+”号变为“ ”(空格),传输数据可以先把数据进行编码(如“+”号替换为对应的编码“%2B”)。

文章小尾巴

文章小尾巴(点击展开)

文章写作、模板、文章小尾巴可参考:《写作“小心思”》
  感谢你看到最后,最后再说两点~
  ①如果你持有不同的看法,欢迎你在文章下方进行留言、评论。
  ②如果对你有帮助,或者你认可的话,欢迎给个小点赞,支持一下~
   我是南方者,一个热爱计算机更热爱祖国的南方人。
  (文章内容仅供学习参考,如有侵权,非常抱歉,请立即联系作者删除。)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1268556.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

立刻解决缺少msvcp140_1.dll解决方法,msvcp140_1.dll修复指南

在日常使用电脑的过程中,我们有时会遇到由于某些重要的DLL文件缺失而导致的程序无法正常启动的问题。很多用户可能都经历过由于缺少msvcp140_1.dll导致应用程序无法运行的情况。本文将为你提供解决msvcp140_1.dll缺失问题的详尽方法,附带对每种方法优点和…

配置自动化部署Jenkins和Gitea

配置自动化部署 这里使用的是JenkinsGitea 如果不知道怎么安装Jenkins和Gitea可以参考下面文章 https://blog.csdn.net/weixin_46533577/article/details/134644144 我的另一篇文章 介绍 前端 先说下自己的情况,因为自己服务器原因,使用的服务器内…

滴滴打车崩了!全过程

滴滴发布致歉10元补偿券,文末可领取 。 事情发生于 2023年11月27日晚~28日中午,滴滴打车服务出现大面积故障,登上微博热搜。 许多用户在使用滴滴出行时遇到了无法叫车、订单异常等问题,导致大量用户滞留在外,出行受阻…

极速整理文件!Python自动化办公新利器

更多资料获取 📚 个人网站:ipengtao.com 当涉及到自动化办公和文件整理,Python确实是一个强大的工具。在这篇博客文章中,我将深入探讨《极速整理文件!Python自动化办公新利器》这个话题,并提供更加丰富和全…

基于单片机智能电子密码锁设计

**单片机设计介绍,基于单片机智能电子密码锁设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机的智能电子密码锁设计是一种利用单片机(如Arduino、Raspberry Pi等)和相关电子元件来…

【鲁班猫创意大赛2期】基于鲁班猫的幼儿Al监督系统

【鲁班猫创意大赛2期】基于鲁班猫的幼儿Al监督系统 作品介绍 本作品名称为“基于鲁班猫的幼儿 Al 学习助手”(系统总体框图如下图),作品应用群体为幼儿群体,主要功能:通过实时坐姿检测,防止坐姿不端正导致…

基于BP神经网络的手写体数字识别matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 filename dir(images\*.bmp); %图像文件格式 load BP.matfilename dir(test\*.bmp); …

深入理解堆排序:建堆、排序与优化

引言 在计算机科学中,堆排序是一种高效的排序算法,利用堆的数据结构特性进行排序。本文将深入探讨堆排序的原理、实现过程,并介绍一种优化方法,以帮助读者更好地理解和运用这一经典算法 目录 堆排序简介 1.1 什么是堆排序&#x…

【精选】VulnHub red 超详细过程思路

🍬 博主介绍👨‍🎓 博主介绍:大家好,我是 hacker-routing ,很高兴认识大家~ ✨主攻领域:【渗透领域】【应急响应】 【java】 【VulnHub靶场复现】【面试分析】 🎉点赞➕评论➕收藏 …

k8s-daemonset、job、cronjob控制器 6

Daemonset控制器(一个节点部署一个) 、 创建Daemonset控制器 控制节点上不能进行部署,有污点 解决方式: 扩容节点,token值过期的解决方法: 回收pod job控制器 需要使用perl镜像,仓库没有&…

PyQt基础_009_ 按钮类控件QSlider

基本功能 import sys from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWidgets import *class SliderDemo(QWidget):def __init__(self, parentNone):super(SliderDemo, self).__init__(parent)self.setWindowTitle("QSlider 例子") self.resize…

优雅测试代码:使用Go实现高效单元测试!

简介 日常开发中, 测试是不能缺少的. Go 标准库中有一个叫做 testing 的测试框架, 可以用于单元测试和性能测试. 它是和命令 go test 集成使用的. 测试文件是以后缀 _test.go 命名的, 通常和被测试的文件放在同一个包中. 单元测试 单元测试的格式形如: func TestAbs(t *t…

Stable Diffusion绘画系列【6】:东方美学作品

《博主简介》 小伙伴们好,我是阿旭。专注于人工智能AI、python、计算机视觉相关分享研究。 ✌更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~ 👍感谢小伙伴们点赞、关注! 《------往期经典推荐--…

速记:一个保险丝检测电路

一个保险丝检测电路 保险丝熔断:红灯亮 保险丝正常:绿灯亮 同样的,仿真中的指示灯可以换成其他指示器件。

谨慎Apache-Zookeeper-3.5.5以后在CentOS7.X安装的坑

目录 前言 一、现场还原 二、问题诊断 三、问题原因 总结 前言 最近由于项目需要,在服务器上需要搭建Hbase完全分布式集群环境。开发环境,采用的是最小节点的方式进行搭建(即3个节点的模式)。资源环境列表如下: 序号…

go学习之文件操作与命令行参数

文章目录 一、文件操作1.基本介绍2.常用文件操作函数和方法3.关于文件操作应用实例4.写文件操作应用实例(创建文件并写入文件)1)基本介绍2)基本应用实例-方式一 5.判断文件是否存在6.统计英文、数字、空格和其他字符数量 二、命令…

Bert-VITS2本地部署遇到的错误

关于Bert-VITS2本地部署遇到的错误 1、在下载python中相关依赖时报错 building ‘hdbscan._hdbscan_tree’ extension error: Microsoft Visual C 14.0 or greater is required. Get it with “Microsoft C Build Tools”: https://visualstudio.microsoft.com/visual-cpp-bu…

如何在安防视频监控平台EasyCVR首页增添统计设备每个小时的温度展示功能?细节如下

安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安…

人工智能对人脑的探索研究!物理限制推动类脑人工智能的发展

原创 | 文 BFT机器人 在一项开创性的研究中,剑桥科学家采用了一种新颖的人工智能方法,展示了物理约束如何深刻影响了人工智能系统的发展。 这项研究会让人想起人脑的发育和能力限制,为复杂神经系统的进化提供了新的见解。通过整合这些限制&a…

基于YOLOv5的人群计数系统设计系统

欢迎大家点赞、收藏、关注、评论啦 ,由于篇幅有限,只展示了部分核心代码。 文章目录 一项目简介系统概述系统功能核心技术系统架构系统优势 二、功能三、系统四. 总结  总结 一项目简介 基于YOLOv5的人群计数系统设计是一个非常有趣且具有挑战性的项目…