oracle中的数据类型char
2015-06-10 16:38
483 查看
今天在做一个前台查询功能的时候,需要从数据库中查询一些数据,显示在前台的jsp页面上,然会自己就写了一个SQL,在Oralce数据库上运行一下,看看是否能查询出数据,结果是没有查询到数据,找个一个上午的问题,终于找到了查询不到数据的问题所在,在我写的查询SQL中包含了一个left join的左连接查询,问题就出在这个左连接查询的连接字段上。
查询不到数据的原因在于 连接的字段的数据类型不一样,
一个表的数据类型定义的为char(2);
另一个表中关联字段定义的数据类型为varchar2(10)
从表面上看这两个数据类型不同的字段在做关联查询的时候应该不会有问题,排除了字段类型的问题,接下来就是看了一下字段中存储的数据的问题,经过仔细的排查对比,果然问题就出现在数据的存储问题上,由于char类型的字段类型,在存储数据的时候会有一个特点,比如,定义一个char(2)长度的数据库字段,如果存储到该字段中的为一个字节的时候,char数据类型的字段会把没有占用的空间补上空格,如果你想在数据库中存一个1,则存到数据库中的数据就会发生变化,会变成“空格1”会多出一个空格,这样就导致了我在做关联查询的时候,怎样也查询不到数据,由于varchar2数据类型是可变存储,在varchar2数据类型的字段中存入1,在数据库中实际存储的就1,不会出现char数据类型的那个种情况,自动的补空格。
最后总结一下原因:
就是char数据类型的空格问题
以后需要注意:
以后在工作的过程中,要特别的注意一下,数据库中字段类型的定义,和对char类型的数据库字段的数据存储问题,合理的定义和存储char类型的数据。
查询不到数据的原因在于 连接的字段的数据类型不一样,
一个表的数据类型定义的为char(2);
另一个表中关联字段定义的数据类型为varchar2(10)
从表面上看这两个数据类型不同的字段在做关联查询的时候应该不会有问题,排除了字段类型的问题,接下来就是看了一下字段中存储的数据的问题,经过仔细的排查对比,果然问题就出现在数据的存储问题上,由于char类型的字段类型,在存储数据的时候会有一个特点,比如,定义一个char(2)长度的数据库字段,如果存储到该字段中的为一个字节的时候,char数据类型的字段会把没有占用的空间补上空格,如果你想在数据库中存一个1,则存到数据库中的数据就会发生变化,会变成“空格1”会多出一个空格,这样就导致了我在做关联查询的时候,怎样也查询不到数据,由于varchar2数据类型是可变存储,在varchar2数据类型的字段中存入1,在数据库中实际存储的就1,不会出现char数据类型的那个种情况,自动的补空格。
最后总结一下原因:
就是char数据类型的空格问题
以后需要注意:
以后在工作的过程中,要特别的注意一下,数据库中字段类型的定义,和对char类型的数据库字段的数据存储问题,合理的定义和存储char类型的数据。
相关文章推荐
- oracle内存管理相关知识整理
- How to Solve oracle.jbo.ConfigException: JBO-33001
- 连接oracle时localhost可以ip地址不可以
- 无oralce客户端pl/sql Dev 如何连接oracle
- Oracle例外定义
- 不安装oracle,配置plsql
- oracle表空间创建
- Oracle 11g Data Guard 使用duplicate from active database 创建 standby database
- Oracle查询server字符集+修改字符集
- Oracle 11gR2 使用 R 4000 MAN duplicate from active database 复制数据库
- Oracle查看字符集后修改oracle服务端和客户端字符集的步骤
- Oracle RMAN DUPLICATE/RESTORE/RECOVER 支持的混合平台
- 解决Oracle10G乱码问题
- Oracle RMAN 兼容性 及 不同版本和不同平台之间使用 常见问题说明
- startup migrate、startup upgrade区别以及Oracle打补丁集文档(转)
- Oracle无法启动,ORA-01034、ORA-01078
- Oracle客户端Dedicated和Shared连接模式
- Oracle数据库之创建表结构
- Oracle建立索引常用的规则
- oracle 游标循环, 查询,异常捕获,继续执行