实时错误’-2147217887‘多步OLB DB 操作产生错误。如果可能,请检查OLE DB状态值

目录

  • 背景
  • 问题
    • 问题分析
    • 问题解决
  • 错误解决与定位技巧
  • 总结

背景

    仍旧是学生信息管理系统的问题,当时做的时候没发现这么多问题呢,只能说明一件事,做的时候没有站在用户的角度考虑需求,设置了什么内容,就按照设置好的去测试,这就是为什么要有专门的测试。在添加和修改用户的时候都报了这个错误
在这里插入图片描述

问题

问题分析

    这个错误表示在使用 OLE DB 进行数据库操作时出现了问题。
    先说说OLE DB是什么,报错总得知道里面的概念是什么

    OLE DB(Object Linking and Embedding Database)是一种面向对象的数据库访问技术,它是微软公司提出的一种标准数据访问接口。它可以让应用程序通过一套通用的接口来访问各种数据源,例如关系型数据库、文件、文本等。OLE DB 技术建立在 COM(Component Object Model)技术之上,它使用面向对象的编程模式,将数据源抽象为一组对象和接口,提供了一种灵活的方式来访问数据。使用 OLE DB,应用程序无需关心具体的数据源类型,只需要和数据源进行统一的交互,从而简化了开发。

    也许你对 OLE DB不清楚是什么,一定听过ADO(ActiveX Data Objects),这个我有专门的博客讲过: ADO实战指南。
ADO建立在OLE DB之上,提供了更简单的编程模型和更易于使用的API。ADO将OLE DB的复杂性隐藏在后面,并提供了一种面向对象的编程模型,让我们能够更方便地访问数据。因此,可以说ADO是OLE DB的一个抽象层,可以帮助开发人员更轻松地使用OLE DB提供的功能。

    再来说说这个错误,应该从哪几方面去考虑:

  • 检查数据库连接是否正确
    确保数据库连接字符串设置正确(上一篇博客: ODBC配置数据源有讲到相关内容),包括数据库名称、登录名和密码等信息。同时确保数据库服务器正在运行,并且有足够的权限进行访问。

  • 检查 SQL 语句是否正确
    如果使用 SQL 语句执行数据库操作,需要确保 SQL 语句的语法正确,包括 SELECT、INSERT、UPDATE、DELETE 等操作语句。可以通过在 SQL Server Management Studio 中测试相同的 SQL 语句来验证语法是否正确。(这点真的非常好用)

  • 确认表名和列名是否正确
    如果使用表名和列名进行数据库操作,需要确保表名和列名正确无误,包括大小写、空格等问题。

  • 检查数据类型是否匹配
    如果使用 ADO/OLE DB 进行数据库操作,需要确保数据类型匹配,例如在插入数据时,要确保插入的数据类型与目标列的数据类型匹配。

  • 代码逻辑错误
    如果以上方法都无法解决问题,需要审查代码,确保没有其他逻辑错误,例如变量名拼写错误、数组越界等问题。

问题解决

    调试代码,定位都字段这里,并且按照上面的方法逐步排查,发现最可能错的应该就在字段,这里需要注意的是,当代码变黄色,不一定就是本行代码出错,可能错误在这个过程中或者之上。
在这里插入图片描述
这个字段对应的数据库中的电话号码字段
在这里插入图片描述
进到表设计里,发现数据类型char的位数写的是10
在这里插入图片描述
问题就出在这里了:

    明眼人一看就知道我们的手机号是11位,可是这里居然设置了10位,接下来直接将char(10)改为char(11)就好了。

    当然也可以使用sql语句

ALTER TABLE student_Info ALTER COLUMN tele_Number CHAR(11)

    如果保存不了(SQL server 2014就保存不了,后面高版本就直接保存了),就使用下面的步骤

打开数据库-----工具栏-----选项----设计器(左侧)----把”阻止保存要求重新创建表的更改“勾掉。
在这里插入图片描述
    至此,问题解决了。

错误解决与定位技巧

    vb报错信息通常是以运行时错误(Runtime Error)的形式呈现。这些错误信息总是说的那么让人不知所云,不能直接理解,虽然,但是,我们是可以通过一些调试技巧来定位和解决错误。比如:

  • 错误编号和错误描述:当运行时错误发生时,VB会提供一个错误编号和错误描述。可以通过查阅相关文档或搜索引擎来获取更多关于特定错误的详细信息,以便理解错误的原因和解决方法。

  • 调试器:VB6内置了一个强大的调试器,可以用来逐步执行代码并查看变量的值、检查语句的执行情况等。可以通过设置断点(Breakpoints)来暂停代码的执行,以便逐行检查代码并观察错误发生的位置。

  • 错误处理:使用错误处理机制(Error Handling)可以帮助捕获和处理运行时错误。通过使用On Error Resume Next和On Error GoTo语句,可以在代码中指定出错时的处理逻辑,例如记录错误日志、显示错误消息等。

  • 输出调试信息:通过在代码中插入一些输出语句,如使用Debug.Print将变量的值输出到调试窗口,可以帮助跟踪代码的执行过程,同时也能够捕获一些隐藏的错误。

  • 分而治之:如果无法确定错误发生的具体位置,可以将代码分成多个模块或函数进行测试。这样可以逐渐缩小错误的范围,并最终确定引起错误的代码段。

  • 日志记录:在关键的代码部分插入日志记录语句,将关键变量的值输出到日志文件中。当出现错误时,可以查看日志文件以了解错误发生时的上下文信息。

总结

    遇到的错误多了,慢慢就知道怎么解决了,但是不要碰,更不要瞎改,要根据错误信息,按照逻辑去分析。另外写代码要站在用户的角度去分析需求,也要站在用户的角度去做测试,在整个开发过程中,始终将用户放在首位,对用户需求进行周密的分析和测试,是确保代码质量和用户满意度的关键所在。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/178534.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【libGDX】使用Mesh绘制圆形

1 前言 使用Mesh绘制三角形 中介绍了绘制三角形的方法,使用Mesh绘制矩形 中介绍了绘制矩形的方法,本文将介绍绘制圆形的方法。 libGDX 以点、线段、三角形为图元,没有提供绘制圆形的接口。要绘制圆形边框,必须通过割圆法逼近圆形&…

防止恶意攻击,服务器DDoS防御软件科普

作为一种恶意的攻击方式,DDoS攻击正以超出服务器承受能力的流量淹没网站,让网站变得不可用。近几年,这种攻击持续增多,由此优秀服务器DDoS防御软件的需求也随之增长。那么如何选择服务器DDoS防御软件,从根本上根除DDoS…

八、ffmpeg录制视频为yuv文件

前言 测试环境: ffmpeg的4.3.2自行编译版本windows环境qt5.12 图片的一些重要知识: RGB图片 位深度:每一个像素都会使用n个二进制位来存储颜色信息。每一个像素的颜色都是由红(Red)、绿(Green&#xff0…

系统移植-交叉编译工具链

不同架构的机器码 与 汇编语言 都不可移植, 且二者一一对应 c语言中三种成分: 1.分号结尾的叫做语句 语句可以让CPU执行,可以进行预处理,编译等生成机器码 2.#开头的为预处理指令 不带分号 CPU无法执行 3.注释,…

Dubbo从入门到上天系列第十八篇:Dubbo引入注册中心简介以及DubboAdmin简要介绍,为后续详解Dubbo各种注册中心做铺垫!

一:Dubbo注册中心引言 1:什么是Dubbo的注册中心? Dubbo注册中心是Dubbo服务治理中极其重要的一个概念。它主要是用于对Rpc集群应用实例进行管理。 对于我们的Dubbo服务来讲,至少有两部分构成,一部分是Provider一部分是…

专业pdf编辑工具PDF Expert mac中文版特点介绍

PDF Expert mac是一款专业的PDF编辑和阅读工具。它可以帮助用户在Mac、iPad和iPhone等设备上查看、注释、编辑、填写和签署PDF文档。 PDF Expert mac软件特点 PDF编辑:PDF Expert提供了丰富的PDF编辑功能,包括添加、删除、移动、旋转、缩放、裁剪等操作…

云原生入门系列(背景和驱动力)

做任何一件事,或者学习、应用一个领域的技术,莫过于先要想好阶段的目标和理解、学习它的意义是什么?解决了什么问题? 这部分,就尝试来探讨下这个阶段需要理解并达成的目标以及践行云原生的意义在哪里。 1.历程 任何阶…

Python 自动化测试如何动态的选择用例执行

问题 在做自动化测试时,往往需要根据任务的不同选择不同的用例集来执行。怎么优雅的来解决这个问题呢? 答案就是:pytest 框架的标记功能。 使用方法如下: 1. 注册标记 在项目根目录下创建 pytest.ini,在其中注册标…

nodejs微信小程序+python+PHP-储能电站运营管理系统的设计与实现-计算机毕业设计推荐

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性:…

SSM之Mybatis框架

1 概述 1.1 什么是Mybayis 它是一款半自动的ORM持久层框架,具有较高的SQL灵活性,支持高级映射(一对一,一对多),动态SQL,延迟加载和缓存等特性,但它的数据库无关性较低。 1.2 什么是ORM ORM(…

《C++ Primer》第9章 顺序容器(三)

参考资料: 《C Primer》第5版《C Primer 习题集》第5版 9.5 额外的string操作(P320) 9.5.1 构造string的其他方法 const char *cp "hello, world!"; char arr[] { h,\0,i,\0 }; string s1(cp); // s1 "hello, world!…

基于STM32的数字图像处理与模式识别算法优化

基于STM32的数字图像处理与模式识别算法优化是一项涉及图像处理和机器学习领域的研究任务,旨在实现高效的图像处理和模式识别算法在STM32微控制器上的运行。本文将介绍基于STM32的数字图像处理与模式识别算法优化的原理和实现步骤,并提供相应的代码示例。…

网络运维与网络安全 学习笔记2023.11.22

网络运维与网络安全 学习笔记 第二十三天 今日目标 VLAN间通信之交换机、VLAN间通信综合案例、浮动路由 VRRP原理与配置、VRRP链路跟踪、VRRP安全认证 VLAN间通信之交换机 单臂路由的缺陷 在内网的VLAN数量增多时,单臂链路容易成为网络瓶颈 三层交换机 具备…

Linux 进程等待

在2号手册里查wait()。wait()等待任意一个子进程的状态。 wait()等待成功会返回该子进程的id,返回失败会返回-1: 小实验 子进程的退出码 子进程执行work(),父进程wait子进程。 子进程跑完5秒之后就e…

AIGC前沿技术与数字创新应用合作交流和论坛发布活动圆满落幕

2023年11月17日下午,AIGC前沿技术与数字创新应用合作交流和论坛发布活动在北京市海淀区牡丹科技楼B座B1报告厅成功举办。 在这个以技术为驱动力的时代,AIGC等这些前沿技术正以惊人的速度改变着我们的生活和产业格局。利用新兴技术和数字化工具来解决问题…

《工程测量学》笔记/期末复习资料

水平角观测方法: ①测回法;②方向观测法(全圆观测法)。 比例尺精度: 图上0.1mm(肉眼能够识别的最小距离)所表示的实地距离称为“比例尺精度”。 ①尺寸小于比例尺精度的地物不需要测量&…

系列十、ThreadLocal的使用场景

一、ThreadLocal的使用场景 (1)使用日期工具类,当用到SimpleDateFormat时,使用ThreadLocal保证线程安全; (2)全局存储用户信息(用户信息存入ThreadLocal,那么当前线程在任…

Kubernetes(k8s)之Pod详解

文章目录 Kubernetes之Pod详解一、Pod介绍pod结构pod定义 二、Pod配置pod基本配置镜像拉取策略启动命令环境变量端口设置资源配额 三、Pod生命周期创建和终止初始化容器钩子函数容器探测重启策略 四、Pod调度定向调度NodeNameNodeSelector 亲和性调度NodeAffinityPodAffinityPo…

2014年6月18日 Go生态洞察:Go 1.3 版本发布

🌷🍁 博主猫头虎(🐅🐾)带您 Go to New World✨🍁 🦄 博客首页——🐅🐾猫头虎的博客🎐 🐳 《面试题大全专栏》 🦕 文章图文…

什么是应急演练脚本?其设计原则是什么?

应急演练脚本是一种系统性、有计划的模拟性文件,旨在测试和评估组织在紧急情况下的应对能力。这种脚本提供了一系列步骤和场景,以确保团队能够高效、协调地应对各种紧急事件。以下将详细探讨应急演练脚本的定义、设计原则以及实施过程。 一、应急演练脚本…
最新文章