oracle数据库sql developer 用SQL可以查到数据,但是项目却查不出来

7 篇文章 0 订阅
7 篇文章 0 订阅

如果字段shzt类型为char(2)类型话,当给shzt=0时,通过PLSQL能查出来一条数据,但是项目运行中查不出来数据。
是因为,PLSQL连接的数据库是Oracle,而Oracle中字段类型为char时,如果值长度不够,Oracle会自动用空格补齐,但是项目中不会自动补齐,必须在代码中补齐长度才可以查的出来。

1.把type类型更改为varchar(),并且删除之前的测试数据 ,重新录入测试数据

2.在sql语句中 where之后的出问题的条件字段做处理where  trim(shzt)=#{shzt}

 public String   checkInit() {
        StringBuilder sql = new StringBuilder();
        sql.append("select * from TD_MPGL where trim(shzt)=5 and trim(cjstate)=0");
        return sql.toString();
    }

还有一种原因:

Oracle在插入数据时没有提交事务,PLSQL里面可以查到,项目中查不到

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值