oracle中的数据类型char

今天在做一个前台查询功能的时候,需要从数据库中查询一些数据,显示在前台的jsp页面上,然会自己就写了一个SQL,在Oralce数据库上运行一下,看看是否能查询出数据,结果是没有查询到数据,找个一个上午的问题,终于找到了查询不到数据的问题所在,在我写的查询SQL中包含了一个left  join的左连接查询,问题就出在这个左连接查询的连接字段上。

查询不到数据的原因在于 连接的字段的数据类型不一样,

 一个表的数据类型定义的为char(2);

另一个表中关联字段定义的数据类型为varchar2(10)

从表面上看这两个数据类型不同的字段在做关联查询的时候应该不会有问题,排除了字段类型的问题,接下来就是看了一下字段中存储的数据的问题,经过仔细的排查对比,果然问题就出现在数据的存储问题上,由于char类型的字段类型,在存储数据的时候会有一个特点,比如,定义一个char(2)长度的数据库字段,如果存储到该字段中的为一个字节的时候,char数据类型的字段会把没有占用的空间补上空格,如果你想在数据库中存一个1,则存到数据库中的数据就会发生变化,会变成“空格1”会多出一个空格,这样就导致了我在做关联查询的时候,怎样也查询不到数据,由于varchar2数据类型是可变存储,在varchar2数据类型的字段中存入1,在数据库中实际存储的就1,不会出现char数据类型的那个种情况,自动的补空格。

最后总结一下原因:

   就是char数据类型的空格问题

以后需要注意:

  以后在工作的过程中,要特别的注意一下,数据库中字段类型的定义,和对char类型的数据库字段的数据存储问题,合理的定义和存储char类型的数据。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值