I have tried to alter the manner in which the data is sent to the database, by using the scripting dictionary. However I am getting confused by the code written by Ultradev. I have included the code below <%@LANGUAGE="VBSCRIPT"%>
<!--#include file="../Connections/CNDS.asp" -->
<%
' *** Edit Operations: declare variables
set Session("inserts"

= Server.CreateObject("Scripting.Dictionary"

MM_editAction = CStr(Request("URL"

)
If (Request.QueryString <> ""

Then
MM_editAction = MM_editAction & "?" & Request.QueryString
End If
' boolean to abort record edit
MM_abortEdit = false
' query string to execute
MM_editQuery = ""
%>
<%
' *** Insert Record: set variables
If (CStr(Request("MM_insert"

) <> ""

Then
MM_editConnection = MM_CNDS_STRING
MM_editTable = "Marks"
MM_editRedirectUrl = "StudentAmend.asp"
MM_fieldsStr = "Choicea|value|Choiceb|value|Choicec|value|Choiced|value|MatriculationNo|value|QuestionID|value"
MM_columnsStr = "Choicea|none,Yes,No|Choiceb|none,Yes,No|Choicec|none,Yes,No|Choiced|none,Yes,No|MatriculationNo|none,none,NULL|QuestionID|none,none,NULL"
' create the MM_fields and MM_columns arrays
MM_fields = Split(MM_fieldsStr, "|"

MM_columns = Split(MM_columnsStr, "|"
' set the form values
For i = LBound(MM_fields) To UBound(MM_fields) Step 2
MM_fields(i+1) = CStr(Request.Form(MM_fields(i)))
Next
' append the query string to the redirect URL
If (MM_editRedirectUrl <> "" And Request.QueryString <> ""

Then
If (InStr(1, MM_editRedirectUrl, "?", vbTextCompare) = 0 And Request.QueryString <> ""

Then
MM_editRedirectUrl = MM_editRedirectUrl & "?" & Request.QueryString
Else
MM_editRedirectUrl = MM_editRedirectUrl & "&" & Request.QueryString
End If
End If
End If
%>
<%
' *** Insert Record: construct a sql insert statement and execute it
If (CStr(Request("MM_insert"

) <> ""

Then
' create the sql insert statement
MM_tableValues = ""
MM_dbValues = ""
For i = LBound(MM_fields) To UBound(MM_fields) Step 2
FormVal = MM_fields(i+1)
MM_typeArray = Split(MM_columns(i+1),","

Delim = MM_typeArray(0)
If (Delim = "none"

Then Delim = ""
AltVal = MM_typeArray(1)
If (AltVal = "none"

Then AltVal = ""
EmptyVal = MM_typeArray(2)
If (EmptyVal = "none"

Then EmptyVal = ""
If (FormVal = ""

Then
FormVal = EmptyVal
Else
If (AltVal <> ""

Then
FormVal = AltVal
ElseIf (Delim = "'"

Then ' escape quotes
FormVal = "'" & Replace(FormVal,"'","''"

& "'"
Else
FormVal = Delim + FormVal + Delim
End If
End If
If (i <> LBound(MM_fields)) Then
MM_tableValues = MM_tableValues & ","
MM_dbValues = MM_dbValues & ","
End if
MM_tableValues = MM_tableValues & MM_columns(i)
MM_dbValues = MM_dbValues & FormVal
Next
MM_editQuery = "insert into " & MM_editTable & " (" & MM_tableValues & "

values (" & MM_dbValues & "

"
If (Not MM_abortEdit) Then
' execute the insert
Set MM_editCmd = Server.CreateObject("ADODB.Command"

MM_editCmd.ActiveConnection = MM_editConnection
MM_editCmd.CommandText = MM_editQuery
MM_editCmd.Execute
MM_editCmd.ActiveConnection.Close
If (MM_editRedirectUrl <> ""

Then
Response.Redirect(MM_editRedirectUrl)
End If
End If
End If
%>
<%
Dim getQuestion
Dim selectQuestion__MMColParam
selectQuestion__MMColParam = "1"
if (Request.QueryString("UnitNo"

<> ""

then selectQuestion__MMColParam = Request.QueryString("UnitNo"

%>
<%
set selectQuestion = Server.CreateObject("ADODB.Recordset"

selectQuestion.ActiveConnection = MM_CNDS_STRING
selectQuestion.Source = "SELECT QuestionID, Question, Answera, Answerb, Answerc, Answerd, UnitNo FROM Question WHERE UnitNo = " + Replace(selectQuestion__MMColParam, "'", "''"

+ ""
selectQuestion.CursorType = 0
selectQuestion.CursorLocation = 2
selectQuestion.LockType = 3
selectQuestion.Open()
selectQuestion_numRows = 0
%>
<%
' *** Recordset Stats, Move To Record, and Go To Record: declare stats variables
' set the record count
selectQuestion_total = selectQuestion.RecordCount
' set the number of rows displayed on this page
If (selectQuestion_numRows < 0) Then
selectQuestion_numRows = selectQuestion_total
Elseif (selectQuestion_numRows = 0) Then
selectQuestion_numRows = 1
End If
' set the first and last displayed record
selectQuestion_first = 1
selectQuestion_last = selectQuestion_first + selectQuestion_numRows - 1
' if we have the correct record count, check the other stats
If (selectQuestion_total <> -1) Then
If (selectQuestion_first > selectQuestion_total) Then selectQuestion_first = selectQuestion_total
If (selectQuestion_last > selectQuestion_total) Then selectQuestion_last = selectQuestion_total
If (selectQuestion_numRows > selectQuestion_total) Then selectQuestion_numRows = selectQuestion_total
End If
%>
<%
' *** Move To Record and Go To Record: declare variables
Set MM_rs = selectQuestion
MM_rsCount = selectQuestion_total
MM_size = selectQuestion_numRows
MM_uniqueCol = ""
MM_paramName = ""
MM_offset = 0
MM_atTotal = false
MM_paramIsDefined = false
If (MM_paramName <> ""

Then
MM_paramIsDefined = (Request.QueryString(MM_paramName) <> ""

End If
%>
<%
' *** Move To Record: handle 'index' or 'offset' parameter
if (Not MM_paramIsDefined And MM_rsCount <> 0) then
' use index parameter if defined, otherwise use offset parameter
r = Request.QueryString("index"

If r = "" Then r = Request.QueryString("offset"

If r <> "" Then MM_offset = Int(r)
' if we have a record count, check if we are past the end of the recordset
If (MM_rsCount <> -1) Then
If (MM_offset >= MM_rsCount Or MM_offset = -1) Then ' past end or move last
If ((MM_rsCount Mod MM_size) > 0) Then ' last page not a full repeat region
MM_offset = MM_rsCount - (MM_rsCount Mod MM_size)
Else
MM_offset = MM_rsCount - MM_size
End If
End If
End If
' move the cursor to the selected record
i = 0
While ((Not MM_rs.EOF) And (i < MM_offset Or MM_offset = -1))
MM_rs.MoveNext
i = i + 1
Wend
If (MM_rs.EOF) Then MM_offset = i ' set MM_offset to the last possible record
End If
%>
<%
' *** Move To Record: if we dont know the record count, check the display range
If (MM_rsCount = -1) Then
' walk to the end of the display range for this page
i = MM_offset
While (Not MM_rs.EOF And (MM_size < 0 Or i < MM_offset + MM_size))
MM_rs.MoveNext
i = i + 1
Wend
' if we walked off the end of the recordset, set MM_rsCount and MM_size
If (MM_rs.EOF) Then
MM_rsCount = i
If (MM_size < 0 Or MM_size > MM_rsCount) Then MM_size = MM_rsCount
End If
' if we walked off the end, set the offset based on page size
If (MM_rs.EOF And Not MM_paramIsDefined) Then
If (MM_offset > MM_rsCount - MM_size Or MM_offset = -1) Then
If ((MM_rsCount Mod MM_size) > 0) Then
MM_offset = MM_rsCount - (MM_rsCount Mod MM_size)
Else
MM_offset = MM_rsCount - MM_size
End If
End If
End If
' reset the cursor to the beginning
If (MM_rs.CursorType > 0) Then
MM_rs.MoveFirst
Else
MM_rs.Requery
End If
' move the cursor to the selected record
i = 0
While (Not MM_rs.EOF And i < MM_offset)
MM_rs.MoveNext
i = i + 1
Wend
End If
%>
<%
' *** Move To Record: update recordset stats
' set the first and last displayed record
selectQuestion_first = MM_offset + 1
selectQuestion_last = MM_offset + MM_size
If (MM_rsCount <> -1) Then
If (selectQuestion_first > MM_rsCount) Then selectQuestion_first = MM_rsCount
If (selectQuestion_last > MM_rsCount) Then selectQuestion_last = MM_rsCount
End If
' set the boolean used by hide region to check if we are on the last record
MM_atTotal = (MM_rsCount <> -1 And MM_offset + MM_size >= MM_rsCount)
%>
<%
' *** Go To Record and Move To Record: create strings for maintaining URL and Form parameters
' create the list of parameters which should not be maintained
MM_removeList = "&index="
If (MM_paramName <> ""

Then MM_removeList = MM_removeList & "&" & MM_paramName & "="
MM_keepURL="":MM_keepForm="":MM_keepBoth="":MM_keepNone=""
' add the URL parameters to the MM_keepURL string
For Each Item In Request.QueryString
NextItem = "&" & Item & "="
If (InStr(1,MM_removeList,NextItem,1) = 0) Then
MM_keepURL = MM_keepURL & NextItem & Server.URLencode(Request.QueryString(Item))
End If
Next
' add the Form variables to the MM_keepForm string
For Each Item In Request.Form
NextItem = "&" & Item & "="
If (InStr(1,MM_removeList,NextItem,1) = 0) Then
MM_keepForm = MM_keepForm & NextItem & Server.URLencode(Request.Form(Item))
End If
Next
' create the Form + URL string and remove the intial '&' from each of the strings
MM_keepBoth = MM_keepURL & MM_keepForm
if (MM_keepBoth <> ""

Then MM_keepBoth = Right(MM_keepBoth, Len(MM_keepBoth) - 1)
if (MM_keepURL <> ""

Then MM_keepURL = Right(MM_keepURL, Len(MM_keepURL) - 1)
if (MM_keepForm <> ""

Then MM_keepForm = Right(MM_keepForm, Len(MM_keepForm) - 1)
' a utility function used for adding additional parameters to these strings
Function MM_joinChar(firstItem)
If (firstItem <> ""

Then
MM_joinChar = "&"
Else
MM_joinChar = ""
End If
End Function
%>
<%
' *** Move To Record: set the strings for the first, last, next, and previous links
MM_keepMove = MM_keepBoth
MM_moveParam = "index"
' if the page has a repeated region, remove 'offset' from the maintained parameters
If (MM_size > 0) Then
MM_moveParam = "offset"
If (MM_keepMove <> ""

Then
params = Split(MM_keepMove, "&"

MM_keepMove = ""
For i = 0 To UBound(params)
nextItem = Left(params(i), InStr(params(i),"="

- 1)
If (StrComp(nextItem,MM_moveParam,1) <> 0) Then
MM_keepMove = MM_keepMove & "&" & params(i)
End If
Next
If (MM_keepMove <> ""

Then
MM_keepMove = Right(MM_keepMove, Len(MM_keepMove) - 1)
End If
End If
End If
' set the strings for the move to links
If (MM_keepMove <> ""

Then MM_keepMove = MM_keepMove & "&"
urlStr = Request.ServerVariables("URL"

& "?" & MM_keepMove & MM_moveParam & "="
MM_moveFirst = urlStr & "0"
MM_moveLast = urlStr & "-1"
MM_moveNext = urlStr & Cstr(MM_offset + MM_size)
prev = MM_offset - MM_size
If (prev < 0) Then prev = 0
MM_movePrev = urlStr & Cstr(prev)
%>
<html>
<head>
<title>Results/Question Page</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
</head>
<body bgcolor="#FFFFFF" text="#000000">
<p>
</p>
<form ACTION="<%=MM_editAction%>" METHOD="POST" name="form1">
<p>Unit Number <%=(selectQuestion.Fields.Item("UnitNo"

.Value)%></p>
<div align="center">
<table width="75%" border="1" cellspacing="3" cellpadding="3" height="544">
<tr align="center" bordercolor="#FFFFFF" valign="top">
<td width="1" height="40" bordercolor="#CCCCCC">
<p><font size="3"><%=(selectQuestion.Fields.Item("Question"

.Value)%></font></p>
</td>
<td width="12" height="12" rowspan="5" valign="top">
<p> </p>
<p> </p>
<p> </p>
<p> </p>
<table align="center" height="274">
<tr valign="middle">
<td nowrap align="right" height="66" width="103" valign="bottom">
<div align="center"><font size="3">
<input type="checkbox" name="Choicea" value=1 >
</font></div>
</td>
<td height="66" width="169" valign="bottom"> <font size="3"> </font></td>
</tr>
<tr valign="middle">
<td nowrap align="right" height="62" width="103" valign="bottom">
<div align="center"><font size="3">
<input type="checkbox" name="Choiceb" value=1 >
</font></div>
</td>
<td height="66" width="169" valign="bottom"> <font size="3"> </font></td>
</tr>
<tr valign="baseline">
<td nowrap align="right" height="62" valign="bottom" width="103">
<div align="center"><font size="3">
<input type="checkbox" name="Choicec" value=1 >
</font></div>
</td>
<td height="66" width="169" valign="bottom"> <font size="3"> </font></td>
</tr>
<tr valign="baseline">
<td nowrap align="right" height="62" valign="bottom" width="103">
<div align="center"><font size="3">
<input type="checkbox" name="Choiced" value=1 >
</font></div>
</td>
<td height="33" width="169" valign="bottom"> <font size="3"> </font></td>
</tr>
<tr valign="baseline">
<td nowrap align="right" height="35" valign="top" width="103"> </td>
<td height="35" width="169"> <font size="3">
<input type="hidden" name="MatriculationNo" value="<%= Session("MM_Matriculation"

%>" size="32">
</font></td>
</tr>
<tr valign="baseline">
<td nowrap align="right" height="37" valign="top" width="103"> </td>
<td height="37" width="169"> <font size="3">
<input type="hidden" name="QuestionID" value="<%=(selectQuestion.Fields.Item("QuestionID"

.Value)%>" size="32">
</font></td>
</tr>
</table>
<p>
</p>
<p> </p>
<p> </p>
<p> </p>
<p> </p>
<p> <font size="3">
<input type="hidden" name="MM_insert" value="true">
</font></p>
<p> </p>
</td>
</tr>
<tr valign="top">
<td width="49%" height="53">
<p><%=(selectQuestion.Fields.Item("Answera"

.Value)%></p>
<p> </p>
</td>
</tr>
<tr valign="top">
<td width="49%" height="59">
<p><%=(selectQuestion.Fields.Item("Answerb"

.Value)%></p>
<p> </p>
</td>
</tr>
<tr>
<td width="49%" height="71"><%=(selectQuestion.Fields.Item("Answerc"

.Value)%></td>
</tr>
<tr valign="top">
<td width="49%" height="444">
<p><%=(selectQuestion.Fields.Item("Answerd"

.Value)%></p>
<p> </p>
<p> </p>
<p> </p>
<p> </p>
<p> </p>
</td>
</tr>
</table>
<input type="submit" value="Insert Record" name="submit">
</div>
<p align="center"><%= Session("MM_Matriculation"

%> </p>
<div align="center">
<table border="0" width="50%" align="center">
<tr>
<td width="23%" align="center">
<div align="center">
<% If MM_offset <> 0 Then %>
<a href="<%=MM_moveFirst%>"><img src="../OtherPages/First.gif" border=0></a>
<% End If ' end MM_offset <> 0 %>
</div>
</td>
<td width="31%" align="center">
<% If MM_offset <> 0 Then %>
<a href="<%=MM_movePrev%>"><img src="../OtherPages/Previous.gif" border=0></a>
<% End If ' end MM_offset <> 0 %>
</td>
<td width="23%" align="center">
<% If Not MM_atTotal Then %>
<a href="<%=MM_moveNext%>"><img src="../OtherPages/Next.gif" border=0></a>
<% End If ' end Not MM_atTotal %>
</td>
<td width="23%" align="center">
<% If Not MM_atTotal Then %>
<a href="<%=MM_moveLast%>"><img src="../OtherPages/Last.gif" border=0></a>
<% End If ' end Not MM_atTotal %>
</td>
</tr>
</table>
</div>
</form>
</body>
</html>
<%
selectQuestion.Close()
%>
I would be very grateful is someone could look at the insert statement and indicate how I can have the selections made by the quiz-taker, into the array, so that all the answers can be inserted at once.
Any ideas