ADO 调用Execute失败,异常码DB_E_DATAOVERFLOW
今天,通过ADO接口往PG数据库中插入数据,结果数据始终不能插入到数据库的表中,执行insert语句后,返回失败,错误码DB_E_DATAOVERFLOW。
DB_E_DATAOVERFLOW:命令中的数值超出列中规定的范围!
原因很清楚了,插入数据表中的字段的变量值范围超过了表定义时的范围,产生了溢出。
一个好的编程习惯:定义字符串类型时最好分配足够大的缓冲空间。
而且,涉及到中英文切换的情况,中文字符串长度较短,但是翻译成英文后长度就可能会明显增大,需要选择两者中最大的长度!
附录:OLE DB函数可能返回的HRESULT错误代码
错误码 描述
DB_E_ABORTLIMITREACHED 执行中断,可能是因为资源不足
DB_E_ALREADYINITIALIZED 企图重新初始化已经初始化的数据源
DB_E_BADACCESSORFLAGS 非法的Accessor标记
DB_E_BADACCESSORHANDLE 非法的Accessor句柄
DB_E_BADACCESSORTYPE 指定的Accessor没有带参数
DB_E_BADBINDINFO 非法的绑定信息
DB_E_BADBOOKMARK 非法的书签
DB_E_BADCHAPTER 非法的章
DB_E_BADCOLUMNID 非法的列号
DB_E_BADCOMPAREOP 比较操作无效
DB_E_BADCONVERTFLAG 非法的转换标记
DB_E_BADCOPY 拷贝出错
DB_E_BADDYNAMICERRORID 传递的DynamicErrorID非法
DB_E_BADHRESULT 传递的HRESULT非法
DB_E_BADID 无法接受DB_E_BADID,请使用DB_E_ABLEID
DB_E_BADLOCKMODE 非法的锁定模式
DB_E_BADLOOKUPID 非法的LookupID
DB_E_BADORDINAL 指定的列参数不存在
DB_E_BADPARAMETERNAME 不能识别给定的参数名称
DB_E_BADPRECISION 指定的精度非法
DB_E_BADPROPERTYVALUE 属性值非法
DB_E_BADRATIO 非法的比例
DB_E_BADRECORDNUM 指定的记录号非法
DB_E_BADREGIONHANDLE 非法的区域句柄
DB_E_BADROWHANDLE 非法的行句柄。在行记录集的开始和结尾或更新结果集时经常发生该错误。
DB_E_BADSCALE 指定的scale非法
DB_E_BADSOURCEHANDLE 非法的源句柄
DB_E_BADSTARTPOSITION 指定的行位移出界
DB_E_BADSTATUSVALUE 指定的状态标记既非DBCOLUMNSTATUS_OK又非DBCOLUMNSTATUS_ISNULL
DB_E_BADSTORAGEFLAG 不支持某个指定的存储标记
DB_E_BADSTORAGEFLAGS 不支持存储标记
DB_E_BADTABLEID 非法的表标识
DB_E_BADTYPE 指定的类型非法
DB_E_BADTYPENAME 给定的类型不能识别
DB_E_BADVALUES 非法的值
DB_E_BOOKMARKSKIPPED 尽管正常形成书签,但没有匹配行
DB_E_BYREFACCESSORNOTSUPPORTED 该供应程序不支持Accessor
DB_E_CANCELED 修改已撤销,列数没有变化
DB_E_CANNOTFREE 供应程序已经是树的所有者,该树不能释放
DB_E_CANNOTRESTART 行集不能重新启动
DB_E_CANTCANCEL 正在执行的命令不能取消
DB_E_CANTCONVERTVALUE 因为非数字溢出原因,命令中的数值不能转换为正确的类型
DB_E_CANTFETCHBACKWARDS 行集不支持向后滚动
DB_E_CANTFILTER 请求的过滤器不能打开
DB_E_CANTORDER 请求的排序器不能打开
DB_E_CANTSCROLLBACKWARDS 行集不能向后滚动
DB_E_CANTTRANSLATE 不能把当前的数描述为文本
DB_E_CHAPTERNOTRELEASED 行集是单章节的,访问新章节时,旧章节没有释放
DB_E_CONCURRENCYVIOLATION 行集使用优化的并行操作,自上次阅读后,列值已经改变
DB_E_COSTLIMIT 在给定的cost限制内不能发现查询计划
DB_E_DATAOVERFLOW 命令中的数值超出列中规定的范围
DB_E_DELETEDROW 所引用的行已经删除
DB_E_DIALECTNOTSUPPORTED 供应程序不支持指定的dialect
DB_E_DUPLICATECOLUMNID 发生重复的列标号
DB_E_DUPLICATEDATASOURCE 发生重复的数据源
DB_E_DUPLICATEINDEXID 指定的索引已经存在
ADO 错误参考:https://msdn.microsoft.com/zh-cn/LIBRARY/jj248997.aspx
OLE DB
函数可能返回的
HRESULT
错误代码
ADO 调用Execute失败,异常码DB_E_DATAOVERFLOW的更多相关文章
- ADO方式,VC调用Execute执行INSERT INTO插入变量SQL语句的写法
		ADO方式,VC调用Execute执行INSERT INTO插入变量SQL语句的写法 有些情况下,SQL SERVER 2008r2中需要保存float,int类型的数据,当C 中的变量为double ... 
- 调用 SSPI 失败,请参见内部异常。接收到的消息异常,或格式不正确。
		完整异常信息: System.Security.Authentication.AuthenticationException: 调用 SSPI 失败,请参见内部异常. ---> System.C ... 
- 调用 SSPI 失败,请参见内部异常  解决方法
		2017-11-12 12:49:53:706] OnServerConnectionAvailable error : System.Security.Authentication.Authenti ... 
- atitit.架构设计---方法调用结果使用异常还是返回值
		atitit.架构设计---方法调用结果使用异常还是返回值 1. 应该返回BOOL类型还是异常 1 2. 最终会有四种状况,抛出异常.返回特殊值.阻塞.超时 1 3. 异常的优缺点点 1 4. jav ... 
- https 调用验证失败 peer not authenticated
		https 调用验证失败 peer not authenticated 报错日志: Caused by: javax.net.ssl.SSLPeerUnverifiedException: peer ... 
- [已解决]:调用 LoadLibraryEx 失败,在 ISAPI 筛选器 "c:\Windows\Microsoft.NET\Framework\v4.0.30319\\aspnet_filter.
		现象:我的是 win7, iis7, 64bit, 打开网站错误如下: 错误摘要 HTTP 错误 500.0 - Internal Server Error 调用 LoadLibraryEx 失败,在 ... 
- 在执行xp_cmdshell的过程中出错,调用'LogonUserW'失败,错误代码:'1909'
		在上篇文章Could not obtain information about Windows NT group/user 'xxxx\xxxx', error code 0x5里面,我介绍了SQL ... 
- Java 集合快速失败异常
		快速失败 在JDK中,查看集合有很多关于快速失败的描述: 注意,此实现不是同步的.如果多个线程同时访问一个哈希映射,而其中至少一个线程从结构上修改了该映射,则它必须 保持外部同步.(结构上的修改是指添 ... 
- [置顶] Ajax程序:处理异步调用中的异常(使用Asp.Net Ajax内建的异常处理方法)
		无论在Window应用程序,还是Web应用程序以对用户友好的方式显示运行时的异常都是很有必要,尤其对于可能有很多不确定因素导致异常的Web应用程序;在传统的Web开发中,处理异常的方式——设计专门一个 ... 
随机推荐
- 每日英语:The Biggest Distraction In The Office Is Sitting Next To You
			The big push in office design is forcing co-workers to interact more. Cubicle walls are lower, offic ... 
- JSON数据乱码问题
			http://ifeve.com/json-code-problem/ ***************************** 背景 程序员一提到编码应该都不陌生,像gbk.utf-8.ascii ... 
- IP地址归属地查询
			http://www.ipip.net/download.html#ip_code 下载免费版 IP 地址数据库. 网站下面有官方给出的查找IP地址所属国家.省.市的办法. python版本列出 py ... 
- eclipse  tomcat timeout时间设置
			eclipse tomcat默认启动timeout时间太短,导致项目启动时间一长,就报错 如下设置: 工作空间\.metadata\.plugins\servers.xml文件 <?xml ve ... 
- poj1509(环形字符串求最小字典序)
			题意:给你一串字符串,但是这串字符串是环形的,让你找个位置切开,使得它的字典序最小....... 思路:典型的最小表示法....... #include<iostream> #includ ... 
- python AES 加密
			pad: ZeroPadding mode: cbc #!/usr/bin/env python# -*- coding:utf-8 -*-# 这里使用pycrypto库# 按照方法:easy_in ... 
- java资料——哈希表(散列表)(转)
			哈希表 散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构.也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度. ... 
- IP数据包格式
			IP数据包格式 0 4 8 16 31 |4位版本 | 4位首部长度 | 8位服务类型 | 16位总长度(字节数)| |16位标识 | 3位标志 | 13位片偏移 | |8位生存时间| 8位协议 | ... 
- HAProxy+Varnish+LNMP实现高可用负载均衡动静分离集群部署
			HAProxy高可用负载均衡集群部署 基本信息: 系统平台:VMware WorkStation 系统版本: CentOS Linux release 7.2.1511 (Core) 内核版本: 3. ... 
- NTP原理
			ntp原理与设置 原创 2016年09月17日 15:28:16 标签: ntp / 原理 / 设置 / linux / 时钟同 ... 
