2021-06-12

在调试过程中遇到一个奇怪的现象,相同的SQL查询在数据库直接执行能获取结果,但在Java项目中却返回空。原因在于SQL查询条件中的char字段含有空格,数据库会自动忽略,而Java中则严格匹配导致条件不成立。这个问题揭示了数据库查询与编程环境中字符串处理的差异,需要注意字符串空白字符的处理方式。
摘要由CSDN通过智能技术生成

同样的SQL语句在数据库中能查出结果,但是在java项目中,执行结果查不到数据

今天在调试的时候发现同样的SQL语句在数据库中能查出结果,但是在java项目中,执行结果查不到数据,原因是查询语句中有一个条件字段有空格,在PLSQL中查询时会自动把字段后的空格去掉,sql中有一个查询条件字段类型是char(8),当这个字段只保存一个字符时,数据库会在后面补充上空格,结果在java项目中查询时条件一直不成立,因为多了空格,而在数据库PLSQL查询时会自动去掉空格,条件成立所以查询出结果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值