oracle数据库表中某个字段设置为NUMBER(10,2),为什么在页面只能输入6位整数,只有超过6位就报错

在页面输入12345678这样的8位数字时,就报错,页面显示为这样的5.423423408E7带有E,要是输入7位整数也会报错,只有输入6位这样123456数字就没有错误... 在页面输入12345678这样的8位数字时,就报错,页面显示为这样的5.423423408E7带有E,要是输入7位整数也会报错,只有输入6位这样123456数字就没有错误,请问NUMBER(10,2),具体是什么意思啊? 展开
 我来答
刘前昌
2012-11-21
知道答主
回答量:3
采纳率:0%
帮助的人:2.9万
展开全部
number(10,2)表示的意思就是这个字段可以存一个10位的数字,其中两位是小数部分,也就是说整数部分有8位,最多可以表示99999999.99。其中小数位数只能小于等于2位,整数位数只能小于等于8位。至于你说的页面输入12345678这样的8位数字时,就报错,应该是你的程序处理中有修改原始的输入数据,导致入库的时候的这个数值超出了前面所说的限制。
whiteamoon
推荐于2018-03-13 · TA获得超过251个赞
知道小有建树答主
回答量:199
采纳率:0%
帮助的人:167万
展开全部
number(10,2) 两位小数 共10位 不算负号和小数点

你应该描述一下报错位置的代码和错误信息?猜测是字符串转数字类型出错了
更多追问追答
追问
当输入12345678时,点击页面的保存按钮,保存到数据库中,之后返回到页面的显示结果是这样的1.2365478E7,而且后台报错信息是这样的,Caused by: java.sql.SQLException: ORA-01438: 值大于为此列指定的允许精度
追答
当输入12345678时,点击页面的保存按钮,保存到数据库中,之后返回到页面的显示结果是这样的1.2365478E7

我可以理解为已经正确保存到数据库中,前台也能正确从数据库读出数据(科学记数法),只是后台有报错信息是吗?

你的报错信息的确来自ORACLE,猜测你的程序存在第二次将1.2365478E7插入到数据库,这个数字就不合法了
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式