请问一个update 问题 急啊

生活旅游网 2008-04-25 04:54:47
我有一个操作生成静态文件的页面,当更新的内容多时(不是记录,是每一个的内容),我如果生成文件后,去更新数据库时,总是说超时,但是我把相应的sql语句放入mssql中执行时,速度不到一秒,可是当在页面中去掉更新语句,页面能顺利完成,而如果加上更新语句,页面一下子会很慢到最后超,请问各位这是什么原因?

先谢谢了!!
...全文
75 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
生活旅游网 2008-04-29
  • 打赏
  • 举报
回复
问题以搞定,打扰各位了
生活旅游网 2008-04-28
  • 打赏
  • 举报
回复
奇怪的是:记录过多的时候还很过,记录少(记录中的内容多的时候就过不了,就超时了)
生活旅游网 2008-04-28
  • 打赏
  • 举报
回复
代码如下:



Dim IdList, ProgramStart, TotalNum, FinishedNum,CreateNum
IdList = FLib.SafeSql(Request("IdList"))
ProgramStart = Time()
TotalNum = 0
FinishedNum = 0
CreateNum = 0
If IdList = "" Then
FLib.Alert "参数有误", "BACK", 0
Response.End
End If

Dim Sql, Rs, TempContent,file_url
Sql="select cm_article.*,cm_class.Nvc_name as classname,cm_class.id as classid,cm_template.Nvc_path,cm_template.Nvc_name as temname,cm_article_group.I_flag from cm_article inner join cm_class on cm_article.I_class_id=cm_class.id inner join cm_template on cm_class.I_class_templateid=cm_template.id left join cm_article_group on cm_article.I_group_id=cm_article_group.id where cm_article.id in ("&IdList&")"
dim templateid,Rs1,Sql1,teamid_list
teamid_list = "0,"

Set Rs = Db.ExeCute(Sql)
Dim flag_1
While Not Rs.Eof
If isnull(Rs("I_flag")) or Rs("I_flag")="" Then
flag_1 ="0"
Else
flag_1 = Rs("I_flag")
End If
if cint(Rs("I_checked"))=1 then '生成审核过的文章
If cstr(Rs("I_group_id")) ="0" or cstr(flag_1) = "0" Then '文章不属于组或组内没有文章
TempContent = Cr.ReadTemplate(Cfg.Template_file&Rs("Nvc_path"))
file_url=CreateRes (Rs, TempContent, Rs("id"))

Db.execute("update cm_article set Nvc_visit_Url='"&file_url&"',I_created=1 where id="&Rs("id"))
Else
If instr(teamid_list,Rs("I_group_id")&",") = 0 Then
CreateRes_team Rs("I_group_id"),Rs("id")
teamid_list = teamid_list &Rs("I_group_id")&","
End If

End If
FinishedNum = FinishedNum+1
end if
TotalNum = TotalNum +1
Rs.MoveNext
Wend
Rs.close




Function CreateRes(Rs,byref TempContent,id)
dim Nvc_nametag1
if TempContent="" or not isnumeric(id) then
FLib.Alert "参数错误!","BACK",0
response.end
end if
Nvc_nametag1 = server.HTMLEncode(Rs("Nvc_name"))
if Rs("Nvc_nametag")<>"" and not isnull(Rs("Nvc_nametag")) then
Nvc_nametag1=replace(Rs("Nvc_nametag"),"[title]",Nvc_nametag1)
end if
dim class_folder,date_folder,file_name,month1,day1,temphour,tempMinute,class_folder1
TempContent = replace(TempContent,"<!--snailcity(title)-->",server.HTMLEncode(Rs("Nvc_name")))
TempContent = replace(TempContent,"<!--snailcity(title1)-->",Nvc_nametag1)
if Rs("D_uptime")="" or isnull(RS("D_uptime")) then
TempContent = replace(TempContent,"<!--snailcity(date)-->",Rs("Createtime"))
else
TempContent = replace(TempContent,"<!--snailcity(date)-->",RS("D_uptime"))
end if
if Rs("Nvc_author")="" or isnull(RS("Nvc_author")) then
TempContent = replace(TempContent,"<!--snailcity(author)-->","嘀嗒")
else
TempContent = replace(TempContent,"<!--snailcity(author)-->",RS("Nvc_author"))
end If

If Rs("Nvc_path") = "template3.htm" Then
TempContent = replace(TempContent,"<!--snailcity(class_title)-->",""&server.HTMLEncode(Rs("classname"))&"")
Else
TempContent = replace(TempContent,"<!--snailcity(class_title)-->","<a href=""/article/class.asp?id="&Rs("classid")&""">"&server.HTMLEncode(Rs("classname"))&"</a>")
End If

TempContent = replace(TempContent,"<!--snailcity(content)-->",Rs("Nt_content"))
TempContent = replace(TempContent,"<!--snailcity(classid)-->",Rs("classid"))
TempContent = replace(TempContent,"<!--snailcity(id)-->",Rs("id"))
if instr(Rs("temname"),"新闻") >0 then
class_folder="news"
else
if instr(Rs("temname"),"产品") >0 then
class_folder="product"
else
if instr(Rs("temname"),"知识") >0 then
class_folder="lore"
else
class_folder="other"
end if
end if
end if
if cint(month(now())) <10 then
month1 = "0"&month(now())
else
month1 = month(now())
end if
if cint(day(now())) <10 then
day1 = "0"&day(now())
else
day1 = day(now())
end if
temphour=Hour(now)
tempMinute=Minute(now)
class_folder1 = server.MapPath(Cfg.Create_file&class_folder&"/"&year(now)&month1&day1)
if Rs("Nvc_visit_Url") <>"" and not isnull(Rs("Nvc_visit_Url")) then
file_name = server.MapPath( Rs("Nvc_visit_Url"))
else
file_name = server.MapPath(Cfg.Create_file&class_folder&"/"&year(now)&month1&day1&"/"&temphour&tempMinute&Rs("id")&".htm")
end if
FLib.CreateFolder(class_folder1)
Cr.Write_file TempContent,file_name
TempContent =""
if Rs("Nvc_visit_Url") <>"" and not isnull(Rs("Nvc_visit_Url")) then
CreateRes = Rs("Nvc_visit_Url")
else
CreateRes=Cfg.Create_file&class_folder&"/"&year(now)&month1&day1&"/"&temphour&tempMinute&Rs("id")&".htm"
end if
End Function

Function CreateRes_team(teamid,id)
if teamid="" or not isnumeric(teamid) or id="" Then Exit Function
Dim team_Rs,TempContent,file_url
Set team_Rs = Db.CreateRs()
team_Rs.Open "select cm_article.I_checked,cm_article.id,cm_article.I_created,cm_article.Nvc_name,cm_article.Nvc_nametag,cm_article.Nvc_visit_Url,cm_article.Nt_content,cm_article.Nvc_author,cm_article.D_uptime,cm_article.Createtime,cm_class.Nvc_name as classname,cm_class.id as classid,cm_template.Nvc_path,cm_template.Nvc_name as temname from cm_article inner join cm_class on cm_article.I_class_id=cm_class.id inner join cm_template on cm_class.I_class_templateid=cm_template.id where cm_article.I_group_id="&teamid&" And cm_article.I_deleted=0 And cm_article.I_checked=1 order by I_page",Db.conn,3,3
dim file_url_list,file_id_list,file_a_i
file_a_i =0
DO While Not team_Rs.eof
If cint(team_Rs("I_checked")) =1 Then
TempContent = Cr.ReadTemplate(Cfg.Template_file&team_Rs(12))
file_url=CreateRes (team_Rs, TempContent, team_Rs(1))
Db.execute("update cm_article set Nvc_visit_Url='"&file_url&"',I_created=1 where id="&team_Rs("id")) '加了这条就不行了


End If
team_Rs.MoveNext
Loop
team_Rs.Close
Set team_Rs = nothing
Set team_Rs = Db.CreateRs()
team_Rs.Open "select Nvc_visit_Url,id,Nvc_file_Url from cm_article Where I_deleted=0 and I_checked=1 and I_created=1 And Nvc_visit_url<>'' And I_group_id="&teamid&" And I_checked=1 order by I_page",Db.conn,3,3
Dim page_str,page_i,page_all,P_url,N_url
page_str =""
P_url =""
N_url =""
page_i =1
DO While Not team_Rs.eof
If team_Rs(2)&"a" <>"a" Then
page_str = page_str &" <a href="""&team_Rs(2)&""" class=""ahu"" >["&page_i&"]</a> "
Else
page_str = page_str &" <a href="""&team_Rs(0)&""" class=""ahu"">["&page_i&"]</a> "
End If
If page_i mod 15 =0 Then page_str= page_str & "<br>"
page_i=page_i+1
team_Rs.MoveNext
Loop
'team_Rs.MoveFirst
team_Rs.Close
Set team_Rs = nothing
Set team_Rs = Db.CreateRs()
team_Rs.Open "select Nvc_visit_Url,id,Nvc_file_Url from cm_article Where I_deleted=0 and I_checked=1 and I_created=1 And Nvc_visit_url<>'' And I_group_id="&teamid&" and I_checked=1 order by I_page",Db.conn,3,1
page_all = page_i
page_i =1
DO While Not team_Rs.eof
If page_i>1 Then
team_Rs.movePrevious
If team_Rs(2)&"a" <>"a" Then
P_url = team_Rs(2)
Else
P_url = team_Rs(0)
End If
team_Rs.MoveNext
End If
If page_i < page_all Then
team_Rs.MoveNext
If Not team_Rs.eof Then
If team_Rs(2)&"a" <>"a" Then
N_url = team_Rs(2)
Else
N_url = team_Rs(0)
End If
Else
N_url = ""
End If
team_Rs.movePrevious
End If
If team_Rs(2) = "" or isnull(team_Rs(2)) Then
Cr.Write_page team_Rs(0),page_str,page_i,P_url,N_url
End If
page_i=page_i+1
team_Rs.MoveNext
Loop
team_Rs.Close
Set team_Rs = nothing

End Function


%>
生活旅游网 2008-04-25
  • 打赏
  • 举报
回复
没有就是加一条conn.execute(update )语句
银狐被占用 2008-04-25
  • 打赏
  • 举报
回复
看看页面是不是进入死循环了。
酷窗版演示:http://www.edd8.com/bbs/index.asp?style=0 简装版演示:http://www.edd8.com/bbs/index2.asp 一点点论坛(http://www.edd8.com/bbs)使用说明 欢迎大家下载使用一点点论坛,在使用论坛前,请认真阅读以下内容: ===================================== 论坛:一点点论坛(http://www.edd8.com/bbs) 主页:一点点星空驿站(http://www.edd8.com/) 站长:叮咚虫(e_Mail:b_li@163.com) 版本:EDD8 Ver.2003 for DV =====================================   一点点论坛是建立在动网论坛基础上的ASP互动论坛,从动网Var5.b109开始论坛结构便开始脱离动网,与动网升级一起,本论坛本身也同时实现了动网新的功能,到519的发布,本人常得论坛本身已功能基本完善,所以决定与动网完全脱离,到动网Final的出现,本论坛也决定不再跟随动网升级了,本人全面对原来的论坛进行了代码优化和版面重排,并升级了部分功能代码,完成了现在这样的论坛。使论坛已经完全脱离了动网,以后也不可以随动网一起升级了!   所以选择本论坛的朋友请先明白,如果采用了本论坛的数据结构,以后就不可以和动网一起升级了,而现有的动网Final版的数据库和本论坛的数据库也是不兼容的!对于动网V5.b519的用户,本人同时在压缩包里提供了升级文件,可以把你519的数据库升级成和本论坛一致的数据结构!   由于一些朋友催得较,部分功能还是没有完善的(但不会出错),我以后也会给出升级包的。所以决定使用本论坛的朋友,请一定要到本站论坛的“站务办公室”进行指定的留言签名,以好我第一时间通知大家升级!   论坛中使用到的部分插件并没有一同奉上,原因是我还没完成代码优化,请过几天到我的论坛上下载。可以下载的插件主要有:社区银行、网络拳皇、可乐吧台球、五子棋等等…… ===================================== 主要特色功能说明: ◎ 双版面设计,用户可以根据不同爱好选择不同的版式(酷窗版和精简版),系统会记录用户的选择,不用重复选择,也不会出现版面混淆等现象; ◎ 发贴回贴互动功能,给用户随机的互动事件,增加用户的参与兴趣; ◎ 增强的UBB代码和JS代码,新增的买卖贴、定时贴等十几种特色功能UBB代码; ◎ 贴子功能加强,增加互动鲜花、鸡蛋、金钱、炸弹等功能,并保存数据作为用户在论坛的人缘依据; ◎ 不好说了,等你去发掘吧,不然又说我叫卖了…… ====================================== 安装说明: 解压就可以了,数据库名称和路径有变动时不要忘了在CONN。ASP中进行相应修改。 (注意:当论坛中一个贴子也没有时,论坛明星会出错,但当你加入贴子后就正常了,大家不要惊慌) 升级:(对519),解压后把你的原519数据库覆盖现数据库,再执行根目录下的UPDATE。ASP文件就行了,如果没有升级成功的提示,说明你的数据不能进行升级! (注意:数据库的升级应做了备份,并在本机上进行!) ====================================== 最后一点说明: 由于论坛本来是打算自己用的,所以在设计的过程中部分变量已经去掉,不能从后台设置了(如表格边框),请大家最好保持现有的风格。 如果还不问题,可以到我的论坛上来交流。??注意,由于本人时间不限,技术支持是有限的,请不要过于强求!

28,391

社区成员

发帖
与我相关
我的任务
社区描述
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
社区管理员
  • ASP
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧