如果我可以寻求帮助,请你来这里... 我对oop结构的简单asp有问题...
帮我处理函数saveata pls。跑步时,
call savedata("insert","test_","name, id","lalala, 222","User_ID=3")
得到错误:
INSERT INTO test_(name,id)VALUES(lalala,222)
... Microsoft VBScript运行时错误'800a01a8'
需要对象:'Conn'
<%
function declare_conn(sql,atr)
dim conn, conn_
set conn = Server.CreateObject("ADODB.Connection")
conn = Connect()
set conn_ = Server.CreateObject("ADODB.Recordset")
strConnect = _T("Driver={MySQL ODBC 3.51 Driver};Server=localhost;"
"Database=MyDatabase;User=MyUserName;Password=MyPassword;Option=4;");
if Cstr(atr)="open" then
conn_.CursorLocation = adUseClient
conn_.Open sql, conn, 3, 2
set conn_.ActiveConnection = nothing
set declare_conn=conn_
else if Cstr(atr)="exec" then
conn.Open
conn.Execute sql
end if
end if
end function
function calldata(a,b,c,d)
dim conn_string, sql_string
if c<>"" and d<>"" then
sql_string="SELECT "&Cstr(a)&" FROM "&Cstr(b)&" WHERE "&Cstr(c)&" = '"&Cstr(d)&"'"
response.write(sql_string)
else
sql_string="SELECT "&Cstr(a)&" FROM "&Cstr(b)
response.write(sql_string)
end if
set conn_string = Server.CreateObject("ADODB.Recordset")
set conn_string = declare_conn(sql_string,"open")
set calldata = conn_string
end function
function savedata(a,b,c,d,e)
dim conn_string, sql_string, c_, d_, update_string
update_string = ""
if Cstr(a)="insert" then
sql_string="INSERT INTO "&Cstr(b)&" ("&Cstr(c)&") VALUES ("&Cstr(d)&")"
end if
response.write(sql_string)
'response.end
if Cstr(a)="update" then
c_ = split(c,", ",-1)
d_ = split(d,", ",-1)
response.write(c_)
response.end
if ubound(c_) = ubound(d_) then
do while not c_.eof
update_string=update_string&"("&Cstr(c_)&"="&Cstr(d_)&"),"
c_.MoveNext : d_.MoveNext
loop
else
%><script type="text/javascript">alert("save function error: array out of bound");</script> <%
end if
if Cstr(e)<>"" then
sql_string="UPDATE "&Cstr(b)&" SET "&update_string&" WHERE "&Cstr(e)
else
sql_string="UPDATE "&Cstr(b)&" SET "&update_string
end if
end if
'set conn_string = Server.CreateObject("ADODB.Recordset")
call declare_conn(sql_string,"exec")
end function
%>
这个错误究竟是什么意思?我在
中创建了与数据库ADO的连接connect()
仍然,我可以毫无问题地运行
calldata()
编辑 - dwerty_weird
为骚动而烦恼..
对于这个问题,我发现,我错过了“Set”:
set conn=Connect()
抱歉...但是对于其他问题,我有问题
call savedata("update","test_","name, id","'lalala', 222","bil=1")
会出错: Microsoft VBScript运行时错误“800a01a8” 所需对象 /bkpi-msn/SPPro/function.asp,第56行 -
任何人都可以帮助我吗?
答案 0 :(得分:0)
您缺少数据中的单引号。 name的值是一个字符串,应该用单引号括起来。
你已经在calldata()中实现了这个,这就是它工作正常的原因。也为savedata更新相同的内容。
注意:这适用于所有字符串参数,可能适用于某些参数 其他方式(使用#)也用于日期/日期时间参数。
请以此为出发点,遵循最佳实践进行开发!
希望这有帮助!
的Vivek