网站首页 > 技术文章 正文
最近碰到一个奇怪的问题,同样的Java代码,在不同的数据库执行,结果集却不同?代码片段如下:
表的定义:
SAMPLE_TABLE ( ID INTEGER, NAME CHAR(20) )
java代码片段:
PreparedStatement pstmt = con.prepareStatement("INSERT INTO SAMPLE_TABLE VALUES (?, ?) ;");
pstmt.setInt(1, 100);
pstmt.setString(2, "Tom");
pstmt.execute();
pstmt.setInt(1, 200);
pstmt.setString(2, "Jerry");
pstmt.execute();
PreparedStatement pseq = con.prepareStatement("select * from sample_table where name=?");
pseq.setString(1,"Jerry");
ResultSet rs = pseq.executeQuery();
上面的片段,开始我觉得是自己写错了。于是用同样的代码的用MySQL数据库去验证代码是否有问题。但是结果是正确的。那么问题可能就出现在2个方面:1、setString传参时,获取参数;2、数据库对CHAR的处理方式不同。接下来就从两个方面来试着跟踪下,看看到底原因是什么导致的?
- JDBC中setString传参
上图是从“ojdbc6-11.2.0.3.jar”中看到的部分代码,其它数据库的jar包,我随机看了1、2个 ,这部分的实现代码,大同小异,基本上都是使用了 length()的参数。那么同样的代码,为什么实现的效果却不一样呢?接下来去数据库里看下,对比图如下:
从上面的两图中,我们很清楚的可以看到,length在检索数据时,MySQL和Oracle中的处理方式不一样。于是去查看了关于两个数据库中关于CHAR的相关处理方式。
- 数据库对CHAR的处理方式
MySQL
Oracle
上面是从相关的文档中,找到的关于CHAR的处理方式。
在写入时,两者的处理方式是是一样的。因为CHAR是定长的数据类型,所以写入数据时,不足定长的数据类型时,后面追加空格,补全定长。然后入库。eg:name(char20), name="Jack",因为“Jack”,只有四位,而name定义的char是20位,所以“Jack”入库时,会自动添加16个空格补够20位然后入库。
在读取时,MySQL默认情况下,会把后面的空格去掉,然后返回结果。Oracle因为没有找到相关的特别说明,但是从验证的结果来看,其并没有对数据的空格进行删除操作,而是把库里存的值,原样返回。
通过上面的分析,我们可以完美的解释,为什么同样的代码,在处理CHAR时,却又不同的结果。既然问题原因我们找到了,那么如何解决此类问题呢?推荐大家使用VARCHAR来代替CHAR。
参考连接:
https://dev.mysql.com/doc/refman/8.0/en/char.html
https://docs.oracle.com/en/database/oracle/oracle-database/19/sqlrf/Data-Types.html#GUID-85E0A0DD-9E90-4AE1-9AD5-93C89FDCFC49
猜你喜欢
- 2024-11-12 IPS专家秘籍第六期:AIX ulimit设置2
- 2024-11-12 运维工程师的修炼手册 运维工程师的修炼手册怎么写
- 2024-11-12 MySQL查询流程篇 mysqljoin查询
- 2024-11-12 数据分析师软件安装必备,SQL Server软件安装手册
- 2024-11-12 MySQL前言篇 mysql数据库的前端
- 2024-11-12 第8篇:Oracle注入漏洞绕waf的新语句
- 2024-11-12 Jenkins操作手册 - 巨详细,一篇足矣
- 2024-11-12 这份MySQL全面手册,受喜爱程度不输任何大厂笔记
- 2024-11-12 为什么选择Oracle NetSuite ERP产品-青岛百洋
- 2024-11-12 阿里p8熬了一个肝出这份32w字软件测试面试手册,Github标星31K+
你 发表评论:
欢迎- 615℃几个Oracle空值处理函数 oracle处理null值的函数
- 607℃Oracle分析函数之Lag和Lead()使用
- 595℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 592℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 586℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 580℃【数据统计分析】详解Oracle分组函数之CUBE
- 569℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 560℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- PageHelper - 最方便的 MyBatis 分页插件
- 面试二:pagehelper是怎么实现分页的,
- MyBatis如何实现分页查询?(mybatis-plus分页查询)
- SpringBoot 各种分页查询方式详解(全网最全)
- 如何在Linux上运行exe文件,怎么用linux运行windows软件
- 快速了解hive(快速了解美国50个州)
- Python 中的 pyodbc 库(pydbclib)
- Linux搭建Weblogic集群(linux weblogic部署项目步骤)
- 「DM专栏」DMDSC共享集群之部署(一)——共享存储配置
- 故障分析 | MySQL 派生表优化(mysql pipe)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)