asp中在JScript中使用RecordSet對象的GetRows
來源:易賢網(wǎng) 閱讀:759 次 日期:2014-08-09 16:22:26
溫馨提示:易賢網(wǎng)小編為您整理了“asp中在JScript中使用RecordSet對象的GetRows”,方便廣大網(wǎng)友查閱!

寫ASP程序時,一般情況總是使用的VBScript,不過也不只是這一種選擇,也可以用JScript。但在用JScript作為ASP的語言時,比用VBScript有一些小小的不方便,比如RecordSet的GetRows方法。

在ASP中操作數(shù)據(jù)庫,一般都要用到RecordSet對象,如果注重程序效率的話,可能就會用到RecordSet對象的GetRows方法,把記錄集對象轉(zhuǎn)換成數(shù)組,而操作數(shù)組在速度上將比用RecordSet對象的MoveNext方法快很多,而且可以在取出數(shù)組后盡早釋放RecordSet對象,從而減少資源的占用,這也是優(yōu)化ASP性能的一個方法。

在VBScript里,用RecordSet.GetRows方法取到的是一個二維數(shù)組,里面的數(shù)據(jù)可以通過遍歷數(shù)組的方式來取得。

假設(shè)現(xiàn)在有一個數(shù)據(jù)庫,其中有一個表名為mytable,有3個字段,名稱分別為id,first,second。

代碼如下:

' code by xujiwei

' http://www.xujiwei.cn/

' 定義變量

Dim conn,rs,data,recN,i

' 連接數(shù)據(jù)庫

Set conn=Server.CreateObject("ADODB.Connection")

conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" &_

Server.MapPath("data.mdb")

' 獲取記錄集

Set rs=conn.Execute("SELECT id,first,second FROM mytable")

' 獲取數(shù)據(jù)數(shù)組

data=rs.GetRows()

' 關(guān)閉記錄集,釋放對象

rs.Close()

Set rs=Nothing

' 獲取記錄數(shù)

recN=UBound(data,2)

' 循環(huán)輸出數(shù)據(jù)

For i=0 To recN

' 注意,數(shù)組下標(biāo)從0開始

' 顯示數(shù)據(jù)庫中數(shù)據(jù)

Response.Write("ID: "&data(0,i)&", First: "&data(1,i)&_

", Second: "&data(2,i)&"<br />")

Next

' 關(guān)閉數(shù)據(jù)庫連接,釋放對象

conn.Close()

Set conn=Nothing

%>

但是在JScript使用時,就會有一個問題,那就是JScript并沒有二維數(shù)組,如果要用GetRows所獲取的數(shù)據(jù),必要將這個VBScript中的二維數(shù)組轉(zhuǎn)換成JScript能識別的數(shù)組,即元素為數(shù)組的一個一維數(shù)組。

在JScript里,用GetRows方法獲取的數(shù)組有一個toArray方法,可以轉(zhuǎn)換成JScript中能用的數(shù)組,但是這個數(shù)組是一維的,也就是說,如果要像在VBScript一樣使用的話,還需要我們自己來做轉(zhuǎn)換。

查閱了MSDN及在網(wǎng)上搜索了相關(guān)的文章之后,我寫了一個數(shù)組轉(zhuǎn)換的函數(shù)用于在JScript中使用GetRows方法。

代碼如下:

<script language="JScript" runat="server">

// code by xujiwei

// http://www.xujiwei.cn/

// 定義變量

var conn,rs,vdata,data,recN,i;

// 連接數(shù)據(jù)庫

conn=Server.CreateObject("ADODB.Connection");

conn.Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+

Server.MapPath("data.mdb"));

// 獲取記錄集

rs=conn.Execute("SELECT id,first,second FROM test");

// 獲取數(shù)據(jù)數(shù)組,并轉(zhuǎn)換成為JScript中可用的數(shù)組類型

vdata=rs.GetRows().toArray();

// 獲取數(shù)據(jù)表的字段數(shù)

i=rs.Fields.Count;

// 關(guān)閉記錄集,釋放對象

rs.Close();

rs=null;

// 轉(zhuǎn)換數(shù)組

data=transArray(vdata,i);

// 獲取記錄數(shù)

recN=data.length;

// 循環(huán)輸出數(shù)據(jù)

for(i=0;i<recN;i++) {

// 注意,數(shù)組下標(biāo)從0開始

// 顯示數(shù)據(jù)庫中數(shù)據(jù)

Response.Write("ID: "+data[i][0]+", First: "+data[i][1]+

", Second: "+data[i][2]+"<br />");

}

// 關(guān)閉數(shù)據(jù)庫連接,釋放對象

conn.Close();

conn=null;

// 數(shù)組轉(zhuǎn)換函數(shù)

// by xujiwei

// 參數(shù):arr - GetRows方法得到的對象用toArray方法得到的數(shù)組

// fieldslen - 數(shù)據(jù)表字段數(shù)

function transArray(arr,fieldslen) {

var len=arr.length/fieldslen,data=[],sp;

for(var i=0;i<len;i++) {

data[i]=new Array();

sp=i*fieldslen;

for(var j=0;j<fieldslen;j++)

data[i][j]=arr[sp+j];

}

return data;

}

</script>

對于一些更新頻率不高,而使用次數(shù)比較多的數(shù)據(jù),可以在成功獲取數(shù)據(jù)數(shù)組之后,用Application對象來緩存起來,從而減少對數(shù)據(jù)庫的查詢次數(shù),一定程序程度上優(yōu)化ASP的性能。

更多信息請查看IT技術(shù)專欄

更多信息請查看網(wǎng)絡(luò)編程
下一篇:ASP問答集
易賢網(wǎng)手機(jī)網(wǎng)站地址:asp中在JScript中使用RecordSet對象的GetRows
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機(jī)號
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報警專用圖標(biāo)