加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

ORA-01401: 插入的值对于列过大   ORA-01438: 值大于此列指定的允许精确度

(2009-05-26 15:33:00)
标签:

杂谈

分类: Oracle Sql

ORA-01401: 插入的值对于列过大

如果要char(40)类型的值插入char(8)的字段内,当然不行

一个汉字占两个字符

如何修改字段长度和类型?

原 表A中 001 VARCHAR2(20)
SQL> alter table A modify 001 CHAR(18);

alter table A modify 001 CHAR(18)

ORA-01438: 值大于此列指定的允许精确度

比如定义为number(4,2),却要插入一个值200.12的话,就会出错啊,原因是number(p,s)的问题。

number(p,s),其中p表示该number的总长度,s为小数位。
如果s为负数,则会取相应位数的取整。
例如,如果number(4,-3),则数字1234的存储值为1000;如果number(4,-2),则数字1234的存储值为1200。

在对数据库表中的字段设定类型时,要注意:
NUMBER(10,6) Double   带有小数
NUMBER(4)     Long     为整数

0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有