hi yuanyuan,请教你个问题,C#往Access插入数据几千行后发生异常,"不能再打开其它表了",是什么原因啊

hi yuanyuan,请教你个问题,C#往Access插入数据几千行后发生异常,"不能再打开其它表了",是什么原因啊,第1张

从基础理论上来讲:

Access是文件存储使用ODBC连接那么如果文件被占用可能会出现

正常ADONET的资源占用完毕会出现

表空间占满会出现

实验以及处理方式

如果是第一种那么请尝试将这个函数做成单例

你现在的代码看起来正确但是没有封装的过程请查阅网上的SQLHELPER等其他DBHelper类,来封装你当前的函数让其作用为:执行一句SQL释放 你现在的做法没错但是从运行上来开OPEN一次会查询N条仅此而已为了排除

如果是3请尝试检查创建ACCESS时有没有设置什么例如文件大小之类的参数

原因

有几个主要的错误原因

这个错误发生在当你的程序试图执行更新数据库或其它类似 *** 作时。这是因为

ADO由于以下的几个原因而不能够写数据库造成的。

1。最普遍的原因是匿名用户帐号(IUSR_MACHINE)对该数据库文件没有写权限

要解决这个问题,在管理器中调整数据库文件的属性,让匿名用户有正确的权限。

当使用ACCESS数据库时,不仅要给文件写的权限,还要给该目录写 的权限,因为

Jet需要在该目录建立一个ldb文件。

2。第二个原因是数据库没有使用正确的模式打开。应该使用下面的方法打开。

SQL = "UPDATE Products Set UnitPrice = 2;"

Set Conn = ServerCreateObject("ADODBConnection")

ConnMode = 3 ''3 = adModeReadWrite

ConnOpen "myDSN"

ConnExecute(SQL)

ConnClose

注意默认的Mode是设置0(adModeUnknown),它是允许更新的。

3。还有可能是在ODBC管理器中将该DSN的只读选项选中。

4。你是在同时更新两个表中的字段,也会出现这个错误信息,解决办法是分开来更新

这两个表中各自字段。

5。当你使用了一个从低版本中(如ACCESS20,ACCESS70)载入到高版本(ACCESS 2000)

中的查询时,在执行这个查询是会出现该错误。

以上就是关于hi yuanyuan,请教你个问题,C#往Access插入数据几千行后发生异常,"不能再打开其它表了",是什么原因啊全部的内容,包括:hi yuanyuan,请教你个问题,C#往Access插入数据几千行后发生异常,"不能再打开其它表了",是什么原因啊、ACCESS查询报错!高分!、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/10154260.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存