开发者社区> 科技小先锋> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

ASP 中常见的错误 80004005 信息

简介:
+关注继续查看
错误信息
Microsoft JET Database Engine 错误 '80004005' 未指定的错误 (Provider 错误)
原因:
权限问题,系统缓存目录权限不足
解决方法:
把系统盘如 C:\WINNT\Temp 目录权限加上 Everyone 可读取权限
错误信息
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC Microsoft Access 97 Driver] The Microsoft Jet database 
engine cannot open the file '(unknown)'. It is already opened exclusively 
by another user, or you need permission to view its data.
原因: 
这个错误发生在当IIS使用匿名帐号(通常是IUSR)时,该帐号在NT中对数据库所在的目录 
没有正确的权限.(这就是为什么在Win95和PWS下没问题,因为win95根本就没有目录权限这一说) 
检查文件和目录的权限. 确定你能够在该目录中有能够新建和删除临时文件的权限。 
这些临时文件其实是数据库建立在同一个目录下的文件, 但是要注意的是,有可能这些文件 
也可能建立在别的目录,例如 /Winnt.
使用NT的文件监视程序监视文件失败时到底是访问了什么目录。 
这个NT的文件监视程序可以在这个地方下载 [url]http://www.sysinternals.com.[/url]
如果你对数据库使用了一个网络地址,例如映射地址,就要检查一下共享文件和目录的权限,
还要检查一下数据源文件(DSN)是否被别的程序标志成为正在使用中, 
这些别的程序一般是Visual InterDev,关闭任何一个InterDev中的正打开和数据库连接的项目。
这个错误还可能发生在这种情况:如果在DSN中使用了一个UNC路径(就是通用命名协议),请改用 
本地路径进行测试,因为如果对本地数据库使用UNC也可能出错。 
还可能发生在这种情况,如果服务器要访问Access中的一个表,而这个表却联接在一个网络服务器上。
错误信息: 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC Microsoft Access 97 Driver] Couldn't use '(unknown)'; file 
already in use.
原因: 
多人使用时数据库被锁定。
错误信息: 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC Driver Manager] Data source name not found and no default 
driver specified.
原因: 
最可能的原因是 ConnectString 是一个在 global.asa 中初始化的 Session 变量 ,但是 global.asa 
却没有正常工作。解决办法是,检查赋值时是否正确:(在你的asp中加入下面的代码)
<%= "'auth_user' is " & request.servervariables("auth_user")%> 
<P> 
<%= "'auth_type' is " & request.servervariables("auth_type")%> 
<P> 
<%= "connection string is " & session("your_connectionstring")%> 
<P>
还有一个原因就是你在你的 ConnectString 中加入了多余的空格,例如 
DSN = MyDSN; Database = Pubs; 
试试改成下面这个样子: 
DSN=MyDSN;Database=Pubs;
如果是 global.asa 还没有工作,检查该文件是否在运用程序的根目录中,或者是虚拟目录的根目录中。
还有可能错误出现的原因是 DSN 名称没找着,这可以采用我提供的 id=36767 的办法解决。 
最后是检查是否安装了最新的驱动程序,既是否是最新的 MDAC 版本。
错误信息 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC Driver Manager] Data source name not ??
原因: 
这个错误有可能是出现在你的计算机上软件安装(或则反安装)的顺序上。 
如果ODBC的版本不一致的话,就会发生该错误。 
解决办法是安装最新版本的MDAC
错误信息: 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC Access 97 ODBC driver Driver]General error Unable to open 
registry key 'DriverId'.
原因: 
这个错误发生在爱从注册表中读取数值的时候。 使用regedit32.exe检查你的注册表的权限。 
你也可以使用NT中的注册表监视程序(NTRegMon)来看读取失败信息。 该程序到这找:[url]http://www.sysinternals.com[/url]
错误信息: 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC SQL Server Driver][dbnmpntw]ConnectionOpen (CreateFile()).
原因: 
两个原因:当一个数据库中包含有分别在不用机器上的许可关系时, 
这也可能发生在同一台机器上,当你给一个关系设置了UNC路径,而另一个关系却是本地路径。 
错误原因是: 
当用户使用IIS匿名帐号登录后,对本地这台机器而言他是有权的,但是对于一个UNC路径的机器, 
另外这台机器是不会认为你当前匿名登录的帐号在它那上面也是合法的。 
这样它就不允许你访问它上面的资源,导致错误。
两个解决办法: 
1. 在IIS工具中,改变IIS匿名帐号成另外一个基于域的帐号。(也就是不使用匿名登录) 
2. 或则在那台你要访问资源的机器上也创建一个和当前匿名帐号同样的帐号,使用同样的密码。
错误信息: 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' Microsoft][ODBC 
Microsoft SQL Driver] Logon Failed()
原因: 
该错误是由 SQL Server 产生的,当它不接受或则不能够认识这个登录帐号的时候,或者没有使用管理员身份登录, 
也可能是在NT中没有SQL影射帐号造成的。
使用系统管理员帐号(SA)登录,一般密码应该为空.注意,这时必须使用 CoonectString 而不能够使用DSN文件。 
因为DSN中没有保存用户名和密码。 
检查NT是否给SQL映射了帐号。
错误信息: 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC SQL Server Driver][SQL Server] Login failed- User: Reason: 
Not defined as a valid user of a trusted SQL Server connection.
原因: 
原因同上。 
试试这个办法:在 SQL Server 的 Enterprise Manager 中,选择 Server/SQL Server/Configure[ASCII 
133]/Security Options/Standard. 
如果是运行在 IIS4 中,取消选择该项目的 Password Synchronization 选项。
错误信息: 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC Microsoft Access 97 Driver] Couldn't lock file.
原因: 
也许是没有正确的权限生成Access数据库的锁定文件(.ldb) 
默认时,该文件和你的数据库是同一个目录的。 
给匿名帐号全权访问数据库共享目录的权限。
有时是因为文件是因为共享时有意使用了只读的权限限制。试试使用下面的代码。 
Set Conn = Server.CreateObject("ADODB.Connection" 
Conn.Mode = adModeShareDenyWrite '8
错误信息: 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC Microsoft Access 97 Driver] '(unknown)' isn't a valid 
path. Make sure that the path name is spelled correctly and that you are 
connected to the server on which the file resides.
原因: 
路径非法。最可能发生在当 Global.asa 和 CoonecntString 被使用到另外一台机器上的时候。
错误信息: 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC SQL Server Driver][SQL Server] The query and the views in 
it exceed the limit of 16 tables.
原因: 
查询太复杂了,对查询有限制。
错误信息: 
Microsoft OLE DB Provider for ODBC Drivers error '80004005' 
[Microsoft][ODBC SQL Server Driver][DBMSSOCN] General network error. Check 
your network document
原因: 
当装有 SQL Server 的机器改名的时候。但是 DSN 还使用了原来的机器名。


本文转自king_819 51CTO博客,原文链接:http://blog.51cto.com/kerry/114819,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
ASP.NET自定义控件组件开发 第一章 第三篇
原文:ASP.NET自定义控件组件开发 第一章 第三篇                                             第三篇:第一章的完结篇     系列文章链接: ASP.
880 0
ASP.NET自定义控件组件开发 第一章 第二篇 接着待续
原文:ASP.NET自定义控件组件开发 第一章 第二篇 接着待续      ASP.NET自定义控件组件开发 第一章 第二篇 接着待续     很感谢大家给我的第一篇ASP.NET控件开发的支持!在写这些之前,我也看了一些例子,想选中一些好上手的例子,这样,可能一些例子大家以前都见过,但是我想说:同样是弹钢琴,同样一首“命运交响曲”,有的人弹的让人荡气回肠,有的人弹的就很一般。
892 0
一起谈.NET技术,asp.net控件开发基础(10)
  集合属性相信大家都很熟悉也很常用,如DropDownList,ListBox等控件             测试1            测试2            测试3           1.实现集合属性效果   经过前面几篇的学习,相信这一篇看起来已经相对简单了.我们要做的就是,先定义一个复杂属性,然后用迭代语句获取数组数据即可。
748 0
6963
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载