帮助中心 >  技术知识库 >  网站相关 >  建站知识 >  AspCms错误号:3704 错误描述:对象关闭时,不允许操作

AspCms错误号:3704 错误描述:对象关闭时,不允许操作

2016-12-06 17:38:12 8948

错误号:3704 错误描述:对象关闭时,不允许操作


这篇文章主要介绍了错误号:3704 错误描述:对象关闭时,不允许操作,需要的朋友可以参考下

“错误号:3704 错误描述:对象关闭时,不允许操作。sql=select top 10 ContentID,a.SortID,a.GroupID,a.Exc.......”

inc/AspCms_MainClass.asp文件,大约900行,原来代码为:

代码如下:


if str="content" or str="news" or str="product" or str="down" or str="pic" then 
sperStrs =conn.Exec("select SpecCategory+'_'+SpecField from {prefix}SpecSet Order by SpecOrder Asc,SpecID", "arr") 
if isarray(sperStrs) then
for each spec in sperStrs
sperStr = sperStr&","&spec 
next
end if


我们修改为:

代码如下:


if str="content" or str="news" or str="product" or str="down" or str="pic" then 
sperStrs =conn.Exec("select SpecCategory+'_'+SpecField from {prefix}SpecSet Order by SpecOrder Asc,SpecID", "arr") 
if isarray(sperStrs) then

sperStr=""
for each spec in sperStrs
sperStr = sperStr&","&spec 
next
end if


因为程序在同一个页面循环{aspcms:content}标签时,原来的代码在后面再调用该标签时会不断累加 sperStr值,造成该标签数量越多,后面的SQL查询字段,而Access数据库,单表最多255个字段,SQL查询里面一次查询也最多不超过255个字段,当累加的字段数超过255个时,运行程序就会出错。此时,会引起inc/AspCms_MainClass.asp文件,大约152行的程序代码,内容是:

代码如下:


If Not DebugMode Then 

if Err then
errid=Err.number:errdes=Err.description:Err.Clear:dbConn.close:set dbConn=nothing:isConnect=false
echoErr err_03,errid,errdes&"sql="&sqlStr
end if
end if


如果有错误,程序代码会关闭数据。于是就出现了前文的错误 。


提交成功!非常感谢您的反馈,我们会继续努力做到更好!

这条文档是否有帮助解决问题?

非常抱歉未能帮助到您。为了给您提供更好的服务,我们很需要您进一步的反馈信息:

在文档使用中是否遇到以下问题: