用過Rs.GetRow的兄弟都知道Rs.GetRow可以更有效率地獲取小容量數據(不適合大容量數據,尤其涉及大對象的時候,容易暴掉,我就爆過一次),PuterJam應用得不錯的說。
但是Rs.GetRow返回的是一個二維數組,我們經常不知道哪段對哪段。這個很麻煩,於是編了一小段程序方便調試用:
Dimds
SetobjRS=objConn.Execute("SELECT*FROM[blog_Upload]WHERE([ul_Quote]LIKE'%"&CStr(ID)&"%')")
ds=objRS.GetRows
objRS.Close()
SetobjRS=Nothing
'建立一個表格
Response.Write"WrittenBySipo(www.dc9.cn)<tablealign=""center""border=""1"">"
Response.Writevbcrlf
Response.Write"<tr><td></td>"
Forj=0ToUBound(ds,1)
Response.Write"<td>ds("&j&",X)</td>"
Next
Response.Write"</tr>"
'每一行
Fori=0ToUBound(ds,2)
Response.Write"<tr><td>ds(X,"&i&")</td>"&vbcrlf
'每一列
Forj=0ToUBound(ds,1)
Response.Write"<td>"
IfIsNull(ds(j,i))Then
Response.Write"Null"
Else
Response.Writeds(j,i)
EndIf
Response.Write"<br>"
Response.Write"<b>ds("&j&","&i&")</b>"
Response.Write"</td>"
Next
Response.Write"</tr>"&vbcrlf
Next
Response.end
--------------------------------------------------------------------------------
獻給菜鳥們:
關於GetRows的小資料:
ADO也提供更有效率方法來取得數據。 GetRows方法傳回一個二維的數組變量,每一行對應Recordset中的一筆記錄,且每一列對應到記錄中的字段。此方法的語法如下:
varArray=rs.GetRows([Rows],[Start],[Fields])
Rows是要讀取記錄的數量;如果想要取得Recordset所有記錄,可用-1或省略此參數。 Start是指出第一個被讀取記錄的書籤;也可以是下列列舉常數中的一個:0-adBookmarkCurrent(目前記錄)、1-adBookmarkFirst(第一筆記錄)、或2-adBookmarkLast(最後記錄)。