批量錄入在數據庫的應用中比較廣泛的,關於批量錄入的方法也有好多種。下面我就結合我實際中的應用,談一下兒我是怎麼實現的。主要用到的是form的集合的概念,通過循環取的所有的集合內數據。考慮到大家看著方便,我把它集成到了一個頁面。
下面是具體的代碼:
batchInput.asp
<%
'#####################################
'FileFunction:批量錄入數據
'Author:Myhon
'Date:2003-8-19
'#####################################
'向數據庫寫入數據
SUBwriteData()
dimrecCnt,i
dimfieldName1,fieldName2,fieldName3
dimconn
dimsqlStr,connStr
connStr="Provider=SQLOLEDB.1;InitialCatalog=myDatabase;DataSource=myhon;UserId=sa;PASSWORD="
setconn=Server.CreateObject("ADODB.Connection")
conn.openconnStr'建立數據庫連接
recCnt=request.form("stu_num").count'取得共有多少條記錄
'批量錄入數據
fori=1torecCnt
fieldName1=trim(request.form("fieldName1")(i))
fieldName2=trim(request.form("fieldName2")(i))
fieldName3=trim(request.form("fieldName3")(i))
sqlStr="insertintomyTable(fieldName1,fieldName2,fieldName3)values('"
sqlStr=sqlStr&fieldName1&"','"
sqlStr=sqlStr&fieldName2&"','"
sqlStr=sqlStr&fieldName3&"')"
'response.writesqlStr
conn.execute(sqlStr)
next
ENDSUB
'顯示成批錄入的界面
SUBInputData()
dimrecCnt,i
%>
<formname="bathInputData"action=""method="post">
<%
recCnt=cint(request.form("recCnt"))
fori=1torecCnt
%>
<inputtype="text"name="fieldName1">
<inputtype="text"name="fieldName2">
<inputtype="text"name="fieldName3">
<%
next
%>
<br>
<inputtype="submit"name="action"value="提交">
</form>
<%
ENDSUB
'指定要批量錄入多少條記錄
SUBassignHowMuch()
%>
<!------指定要錄入多少條記錄-------------->
<formname="form1"action=""method="post">
您要錄入的記錄的條數:<inputtype="text"name="recCnt">
<inputtype="submit"name="action"value="下一步>>">
</form>
<%
ENDSUB
ifrequest.form("action")="下一步>>"then