SQL state [null]; error code [0]; Invalid scale size

本文介绍了Oracle10g连接Oracle11g时遇到的问题及解决方案,包括修改SQL查询语句以避免使用通配符*、调整结果集获取方式以及解决dlink连接密码问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述;oracle10g连接oracle11g  视图v_pick_orders_watch 取自11g数据
javax.servlet.ServletException: StatementCallback; uncategorized SQLException for SQL [select *

from v_pick_orders_watch]; SQL state [null]; error code [0]; Invalid scale size. Cannot be less

than zero; nested exception is java.sql.SQLException: Invalid scale size. Cannot be less than

zero
 org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:515)
 org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:419)


root cause
解决:1、原有后台解析sql用了 *;应该写上相应的字段名称;注意把数据字段用nvl(字段,0)函数;保证有数据;
      2、SqlRowSet rs = this.getJdbcTemplate().queryForRowSet(sql);结果集是null;也会报错;
      改为其他方式获取;如this.getJdbcTemplate().queryForList(sql);原因是Spring中实现的问题;
      3、oracle9i或oracle10个dlink连接oracle11g的密码加“小写密码”;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值