最初の SQL クエリの結果セットのレコードをループ コントロールとして使用し、後続の SQL ステートメントに値を入力しようとしています。後者の SQL ステートメント resultSet は、並べ替えの HTML テーブルを設定するために使用されます。
これを達成しようとしているときに、この問題にぶつかりました
Microsoft VBScript コンパイル エラー '800a0410'
'for' ループ制御変数が無効です
/ps/testcli.asp、83行目
RS.Fields の各 objFieldValue
------------------------------------^
私の最初の考えでは、clientRS と RS を区別できなかったのですが、そうではないようです。以下の行は 39 ~ 97 から始まります
SQLDel = "DELETE * FROM ClientModuleList"
SQLDel2 = "DELETE FROM PSS.dbo.TestCli"
'------
SQLGetClientsV1MVSOld = "SELECT ClientID FROM PSS.dbo.CLIENTS WHERE CardpacVersion='Cardlink 1.0' AND OS='MVS'AND Base='Old'AND Active='1'"
SQLGetClientsV1MVSNew = "SELECT ClientID FROM CLIENTS WHERE CardpacVersion='Cardlink 1.0' , OS='MVS', Base='New', Active='1'"
SQLGetClientsV1AS4Old = "SELECT ClientID FROM CLIENTS WHERE CardpacVersion='Cardlink 1.0' , OS='AS4', Base='Old', Active='1'"
SQLGetClientsV2MVSOld = "SELECT ClientID FROM CLIENTS WHERE CardpacVersion='Cardlink 2.0' , OS='MVS', Base='Old', Active='1'"
'------
SQLGetModules01 = "SELECT Patchlib FROM "
SQLGetModules02 = " WHERE Type='B' AND Required='1'"
'-- Connection --
Set connDBO = Server.CreateObject("ADODB.Connection")
'-- ResultSets --
Set clientRS = Server.CreateObject("ADODB.RecordSet")
Set RS = Server.CreateObject("ADODB.RecordSet")
If Request.Form("submit") <> "" Then
'--Delete All Existing Rows --S001--
connDBO.open cString
connDBO.execute(SQLDel2)
connDBO.close
'--Delete All Existing Rows --E001--
'--Get all Clients which satisfy (Cardlink 1.0, MVS, Old, Active) into clientsRS --S002--
clientRS.Open SQLGetClientsV1MVSOld, cString
While NOT clientRS.EOF
For Each objFieldValue in clientRS.Fields
SQLGetModuleFull = "" & SQLGetModule01 & objFieldValue.Value & SQLGetModule02 & ""
RS.Open SQLGetModuleFull, cString
Response.Write("<table border='1'>" )
Response.Write("<tr>" )
For Each objFieldName in RS.Fields
Response.Write("<th>" & objFieldName.Name & "</th>" )
Next
Response.Write("</tr>" )
If NOT RS.EOF Then
While NOT RS.EOF
Response.Write("<tr>" )
For Each objFieldValue in RS.Fields
Response.Write("<td>" & objFieldValue.Value & "</td>" )
Next
Response.Write("</tr>" )
RS.MoveNext
WEnd
Response.Write("</table>" )
End If
Next
WEnd
RS.Close
clientRS.Close
End If
なぜこれが起こるのかについてのヒントはありますか?ASP Classic で使用される VBScript は初めてです