免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1420 | 回复: 5
打印 上一主题 下一主题

OCI精度问题,请教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-03-23 09:23 |只看该作者 |倒序浏览
我现在要把一组char类型数据插入到数据库中,假设如下


  1. struct  a
  2. {
  3.        int                     iTestInt;
  4.        long                  lTestLong;
  5.        unsigned char   cTestChar;
  6.        char                  strTestStr[20];
  7. }
复制代码

将这个结构体插入到数据库中,其中缓存设置如下
                  类型        长度
iTestInt :       SQLT_INT       sizeof(int)
iTestLong:     SQLT_INT       sizeof(long)
cTestChar:     SQLT_UIN      sizeof(int)
strTestStr:     SQLT_STR       (20+2)*sizeof(char)

然后使用将把 struct a中的各个字段用 memcpy(pBuf, &a.iTestInt,sizeof(a.iTest)) 的方式进行赋值。
在 OCIBindByPos(),然后 OCIStmtExecute()的时候,就会出现这个错误:
ORA-01438: value larger than specified precision allows for this column
如果不对缓冲空间赋值的话,就可以成功执行OCIStmtExecute。

请大家帮忙,怎么实现精度控制啊?

论坛徽章:
0
2 [报告]
发表于 2006-03-23 09:39 |只看该作者
OCIStmtExecute()执行的问题吗?

你把当时的各值提出来,直接plsql上插入可以进库吗?

论坛徽章:
0
3 [报告]
发表于 2006-03-23 09:42 |只看该作者
我怀疑是我在memcpy的时候,导致出了数据的精度出了问题。所以现在想做一下精度控制,就是不知道怎么做。

论坛徽章:
0
4 [报告]
发表于 2006-03-23 09:52 |只看该作者
原帖由 UnixPanther 于 2006-3-23 09:42 发表
我怀疑是我在memcpy的时候,导致出了数据的精度出了问题。所以现在想做一下精度控制,就是不知道怎么做。


你把memcpy后的值调出来就可以看到了呀?如果是期望的值那么就直接到plsql里面插入试下

论坛徽章:
0
5 [报告]
发表于 2006-03-23 12:27 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
6 [报告]
发表于 2006-03-23 22:22 |只看该作者
我今天修改了一下,是我分配的空间过大了。其实
cTestChar:     SQLT_UIN      sizeof(int),分配的空间有些大,
把他修改为 cTestChar:     SQLT_UIN      sizeof(char),
就不再抱错了。看来是分配大空间也不是一件好事。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP