У меня есть 2D-массив, который заполняется данными из базы данных, которая затем используется в цикле while с другим SQL-запросом. Для каждого элемента в цикле while я проверяю определенные элементы в массиве 2d, используя цикл for.
Как я могу ускорить это, потому что элементы в цикле while находятся в пределах 1000-2000 элементов, и загрузка веб-страницы занимает 3-4 секунды.
Вот мой 2d массив -
'MultiDimensional Array
Dim permissionsArray()
Dim permissionsCount
connectionstring = obj_ADO.getconnectionstring
Increment = 1
set c = CreateObject("ADODB.Connection")
set r = CreateObject("ADODB.Recordset")
c.open connectionstring
SQL = "select Count(P_Name) as permissionsCount from l_objectpermission inner join A_Permission on op_permissionID = P_permissionID"
r.open SQL, c
permissionsCount = r("permissionsCount")
r.close
c.close
Set objCon = CreateObject("ADODB.Connection")
Set objRS = CreateObject("ADODB.Recordset")
objCon.Open connectionstring
SQL = "select OP_ObjectID, P_Name from l_objectpermission inner join A_Permission on op_permissionID = P_permissionID order by P_Name"
objRS.open SQL, objCon
Redim permissionsArray(2, permissionsCount)
if not objRS.EOF then
objRS.MoveFirst
while not objRS.EOF
permissionsArray(0, increment) = objRS("OP_ObjectID")
permissionsArray(1, increment) = objRS("P_Name")
objRS.MoveNext
Increment = Increment + 1
wend
objRS.close
objCon.close
end if
и внутри моего цикла while -
Page_ID = objRS("P_PageID")
for i = 0 to (permissionsCount)
if permissionsArray(0, i) = Page_ID then
%>
<li style="height: 2px;">
<%=permissionsArray(1,i)%>
</li>
</br>
<%
end if
next
%>
</div></center></td>