mysql版本升级引发的问题_MySQL
bitsCN.com
mysql版本升级引发的问题
问题描述:
1. ibatis 中 mysql语句
Java代码
SELECT d.qid,GROUP_CONCAT(epq.qid) qids
FROM table1 d,table2 epq
WHERE d.qid=#qid#
AND d.pid=epq.pid
GROUP BY d.checkPid
LIMIT 1
2. service层代码
Java代码
Map
if(tempMap != null){
byte[] arr = (byte[])tempMap.get("qids");
String tempQids = new String(arr);
tempMap.put("qids", tempQids);
this.qids.add(tempMap);
}
3. 在测试服务器上测试时,发现一直报2中刷红部分一直报 类型转换错误
4. 采用了N种办法
(1) 本地与svn代码
(2) 对比 测试 与 正式的代码
(3) 对比测试与正式数据的差异性
实在找不到原因
(4) 开始怀疑 mysql驱动
(5) mysql数据库版本
最终竟然 锁定在mysql数据库版本
由于数据库(测试库) 上个月刚采用了 mysql 5.5 ,而正式上还没有发布,仍旧采用的mysql 5.1,真正原因。
如下原因:
当你用group_concat的时候请注意,连接起来的字段如果是int型,一定要转换成char再拼起来,
否则在你执行后(ExecuteScalar或者其它任何执行SQL返回结果的方法)返回的将不是一个逗号隔开的串,
而是byte[]。
该问题当你在SQLyog等一些工具中是体现不出来的,所以很难发现。
select group_concat(ipaddress) from t_ip 返回逗号隔开的串
select group_concat(id) from t_ip 返回byte[]
select group_concat(CAST(id as char)) from t_dep 返回逗号隔开的串
select group_concat(Convert(id , char)) from t_dep 返回逗号隔开的串
bitsCN.com
热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

MySQL 8.4(截至 2024 年的最新 LTS 版本)中引入的主要变化之一是默认情况下不再启用“MySQL 本机密码”插件。此外,MySQL 9.0完全删除了这个插件。 此更改会影响 PHP 和其他应用程序

Java 8引入了Stream API,提供了一种强大且表达力丰富的处理数据集合的方式。然而,使用Stream时,一个常见问题是:如何从forEach操作中中断或返回? 传统循环允许提前中断或返回,但Stream的forEach方法并不直接支持这种方式。本文将解释原因,并探讨在Stream处理系统中实现提前终止的替代方法。 延伸阅读: Java Stream API改进 理解Stream forEach forEach方法是一个终端操作,它对Stream中的每个元素执行一个操作。它的设计意图是处

胶囊是一种三维几何图形,由一个圆柱体和两端各一个半球体组成。胶囊的体积可以通过将圆柱体的体积和两端半球体的体积相加来计算。本教程将讨论如何使用不同的方法在Java中计算给定胶囊的体积。 胶囊体积公式 胶囊体积的公式如下: 胶囊体积 = 圆柱体体积 两个半球体体积 其中, r: 半球体的半径。 h: 圆柱体的高度(不包括半球体)。 例子 1 输入 半径 = 5 单位 高度 = 10 单位 输出 体积 = 1570.8 立方单位 解释 使用公式计算体积: 体积 = π × r2 × h (4

Spring Boot简化了可靠,可扩展和生产就绪的Java应用的创建,从而彻底改变了Java开发。 它的“惯例惯例”方法(春季生态系统固有的惯例),最小化手动设置

PHP连接MySQL后页面空白,die()函数失效的原因分析在学习PHP和MySQL数据库连接的过程中,常常会遇到一些让人困惑...

堆栈是遵循LIFO(最后,首先)原理的数据结构。换句话说,我们添加到堆栈中的最后一个元素是第一个要删除的元素。当我们将(或推)元素添加到堆栈中时,它们就会放在顶部;即最重要的

Intellij Idea简化了Spring Boot的开发,使其成为Java开发人员的最爱。 它的惯例与配置方法最小化了样板代码,从而使开发人员可以专注于业务逻辑。本教程展示了两个metho

本教程将指导您如何使用 Java 将堆栈元素按升序排序。堆栈是计算机科学中的基本数据结构,遵循后进先出 (LIFO) 原则。 我们将分解一种简单而有效的方法,该方法使用额外的临时堆栈,提供详细的分步说明,并包含完整的代码示例。本教程非常适合那些希望增强对堆栈操作的理解并提高 Java 编程技能的人。 使用 Java 将堆栈按升序排序 堆栈就像一堆书,你只能取走最上面的那本。即,堆栈以后进先出的 (LIFO) 方式存储项目。最后添加的项目是第一个被移除的项目。以下是使用辅助堆栈对堆栈元素进行排序的
