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

前言

最近,在工作上接手的任务中,各种 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.mzph.cn/news/182762.shtml

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

相关文章

用行云管家实现IT统一运维管理,提高运维效率

随着公司业务的不断壮大,需要用到的IT系统也越来越多,使用起来耗时耗力。因此实现IT统一运维管理已成为提高运维效率、降低成本、优化资源配置的重要途径。这里我们小编告诉您,用行云管家实现IT统一运维管理,提高运维效率&#xf…

目标检测——R-CNN算法解读

论文:Rich feature hierarchies for accurate object detection and semantic segmentation 作者:Ross Girshick, Jeff Donahue, Trevor Darrell, Jitendra Malik 链接:https://arxiv.org/abs/1311.2524 代码:http://www.cs.berke…

高度自定义进度条实现完整代码附示意图

实现功能&#xff1a; 自定义一个进度条&#xff0c;能手动拖动进度条&#xff0c;也可以点击相应的进度&#xff0c;根据当前进度条的进度显示相应的内容。 效果图&#xff1a; 实现代码&#xff1a; 封装组件&#xff1a; <template><view class"boomBg&qu…

AIoT智能物联网平台技术架构参考

具体来说&#xff0c;AIoT平台能够实现智能终端设备之间、不同系统平台之间、不同应用场景之间的互融互通&#xff0c;进一步推动万物互联的进程。 AIoT智能物联网平台是结合了人工智能&#xff08;AI&#xff09;和物联网&#xff08;IoT&#xff09;技术的平台。它旨在通过物…

达梦数据库使用

达梦数据库使用 &#x1f4d1;前言 本文主要是【达梦数据库】——达梦数据库简单使用的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是听风与他&#x1f947; ☁️博客首页&#xff1a;CSDN主页听风与他…

【Web】NodeJs相关例题wp

目录 ①[GKCTF 2020]ez三剑客-easynode ②[MoeCTF 2021]fake game ③[安洵杯 2020]Validator ④ [HZNUCTF 2023 final]eznode ⑤[CNSS] &#x1f3ed; EzPollution_pre ⑥[CNSS]✴️ EzPollution ①[GKCTF 2020]ez三剑客-easynode const express require(express); co…

如何缓解可观察性挑战?

可观察性正在成为当代 DevOps 实践的基石。即使传统上不属于 DevOps 的部门也看到了在可观察性团队的支持下带来的好处。然而&#xff0c;到 2023 年&#xff0c;组织发现采用之路比预期更加崎岖。以下是 DevOps 团队在可观察性方面面临的七个最大挑战以及一些缓解这些挑战的建…

数据结构 -- 并查集与图

目录 1.并查集 1.结构 2.原理 3.代码实现 1.存储 2.寻找根节点 3.是否为同一集合 4.求集合个数 5.合并为同一集合中 整体代码 2.图 1.基本知识 1.各个属性 2.特殊名词 3.图的解释 2.图的表示 1.邻接矩阵 2.邻接表 3.图的遍历 1.BFS--广度优先遍历 2.DFS--…

Spark on yarn 模式的安装与部署

任务描述 本关任务&#xff1a; Spark on YARN 模式的安装与部署。 相关知识 为了完成本关任务&#xff0c;你需要掌握&#xff1a; Spark 部署模式的种类&#xff1b;Spark on YARN 模式的安装。 Spark 部署模式 Spark 部署模式主要分为以下几种&#xff0c;Spark Stand…

2021年2月1日 Go生态洞察:VS Code Go扩展中默认启用Gopls

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

rss服务搭建记录

layout: post title: RSS subtitle: vps搭建RSS服务 date: 2023-11-27 author: Sprint#51264 header-img: img/post-bg-universe.jpg catalog: true tags: - 折腾 文章目录 引言RSShub-dockerRSS-radarFreshrssFluent reader获取fever api配置Fluent Reader同步 结语 引言 一个…

IDEA设置方法注释模板

目录 一.打开设置&#xff1a;File—>Settings... 二.选择Live Templates—>点击右侧 "" 号—>选择Template Group... 三.输入组名称&#xff0c;建议取容易理解的名字&#xff0c;点击OK 四.选中创建好的组&#xff0c;再次点击 "" 号&#…

“大型”基础模型中幻觉的调查

Abstract 基础模型 (FM) 中的幻觉是指生成偏离事实或包含捏造信息的内容。这篇调查论文广泛概述了近期旨在识别、阐明和解决幻觉问题的努力&#xff0c;特别关注“大型”基础模型&#xff08;LFM&#xff09;。该论文对LFM特有的各种类型的幻觉现象进行了分类&#xff0c;并建…

手撕A*算法(详解A*算法)

A*算法原理 全局路径规划算法&#xff0c;根据给定的起点和终点在全局地图上进行总体路径规划。 导航中使用A*算法计算出机器人到目标位置的最优路线&#xff0c;一般作为规划的参考路线 // 定义地图上的点 struct Point {int x,y; // 栅格行列Point(int x, int y):x(x),y(y){…

java学习part18抽象类

Java抽象类 详解-CSDN博客 111-面向对象(高级)-抽象类与抽象方法的使用_哔哩哔哩_bilibili 1.概念 2.抽象类 抽象类不能实例化&#xff0c;可以有属性&#xff0c;也可以有方法。 方法可以实现或者只声明不实现&#xff0c;要加一个abstract abstract class A{//定义一个抽…

springboot整合redis+自定义注解+反射+aop实现分布式锁

1.定义注解 import java.lang.annotation.*; import java.util.concurrent.TimeUnit;/** Author: best_liu* Description:* Date: 16:13 2023/9/4* Param * return **/ Retention(RetentionPolicy.RUNTIME) Target({ElementType.METHOD}) Documented public interface RedisLo…

Go语言基础:包、函数、语句和注释解析

一个 Go 文件包含以下几个部分&#xff1a; 包声明导入包函数语句和表达式 看下面的代码&#xff0c;更好地理解它&#xff1a; 例子 package mainimport "fmt"func main() { fmt.Println("Hello World!") }例子解释 第 1 行&#xff1a; 在 Go 中&am…

基于SSM的仓库管理系统的设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…

15个超级实用的Python操作,肯定有你意想不到的!

文章目录 1&#xff09;映射代理&#xff08;不可变字典&#xff09;2&#xff09;dict 对于类和对象是不同的3) any() 和 all()4) divmod()5) 使用格式化字符串轻松检查变量6) 我们可以将浮点数转换为比率7) 用globals()和locals()显示现有的全局/本地变量8) import() 函数9) …

【LeetCode刷题】--90.子集II

90.子集II class Solution {public List<List<Integer>> subsetsWithDup(int[] nums) {List<List<Integer>> ans new ArrayList<>();List<Integer> list new ArrayList<>();//排序后便于去重Arrays.sort(nums);dfs(0,nums,ans,lis…