该范例使用 AddNew 方法创建具有指定名称的新记录。
Public Sub AddNewX() Dim cnn1 As ADODB.Connection Dim rstEmployees As ADODB.Recordset Dim strCnn As String Dim strID As String Dim strFirstName As String Dim strLastName As String Dim booRecordAdded As Boolean ' 打开连接。 Set cnn1 = New ADODB.Connection strCnn = "Provider=sqloledb;" & _ "Data Source=srv;Initial Catalog=pubs;User Id=sa;Password=;" cnn1.Open strCnn ' 打开雇员表。 Set rstEmployees = New ADODB.Recordset rstEmployees.CursorType = adOpenKeyset rstEmployees.LockType = adLockOptimistic rstEmployees.Open "employee", cnn1, , , adCmdTable ' 从用户获取数据,雇员 ID 的格式必须为: ' 名、中间名和姓的三个首字母, ' 五位数字,以及性别标识 M 或 F。 ' 例如,Bill Sornsin 的雇员 ID 为:B-S55555M。 strID = Trim(InputBox("Enter employee ID:")) strFirstName = Trim(InputBox("Enter first name:")) strLastName = Trim(InputBox("Enter last name:")) ' P只在用户输入姓和名之后进行。 If (strID <> "") And (strFirstName <> "") _ And (strLastName <> "") Then rstEmployees.AddNew rstEmployees!emp_id = strID rstEmployees!fname = strFirstName rstEmployees!lname = strLastName rstEmployees.Update booRecordAdded = True ' 显示新添加的数据。 MsgBox "New record: " & rstEmployees!emp_id & " " & _ rstEmployees!fname & " " & rstEmployees!lname Else MsgBox "Please enter an employee ID, " & _ "first name, and last name." End If ' 删除新记录,因为这只是演示。 cnn1.Execute "DELETE FROM employee WHERE emp_id = '" & strID & "'" rstEmployees.Close cnn1.CloseEnd Sub
VBScript 版本
下面是使用 VBScript 编写、并用于 Active Server Page (ASP) 的相同范例。如需查看该完整功能范例,请使用与 IIS 一同安装并位于 C:\InetPub\ASPSamp\AdvWorks 的数据源 AdvWorks.mdb,来创建名为 AdvWorks 的系统“数据源名称”(DSN)。这是 Microsoft Access 数据库文件。请使用“查找”命令定位文件 Adovbs.inc,并将其放入计划使用的目录中。请将以下代码剪切并粘贴到“记事本”或其他文本编辑器中,另存为 AddNew.asp。这样,便可在任何客户端浏览器中查看结果。
如要执行此范例,请按 HTML 格式添加虚构的新记录,单击“添加新记录”。查看 Delete 方法范例可删除不需要的记录。
<!-- #Include file="ADOVBS.INC" --> <% Language = VBScript %> <HTML><HEAD><TITLE>ADO Open Method</TITLE> </HEAD><BODY> <FONT FACE="MS SANS SERIF" SIZE=2> <Center><H3>ADO AddNew Method</H3> <!-- ADO Connection Object used to create recordset--> <% '创建并打开 Connection 对象。 Set OBJdbConnection = Server.CreateObject("ADODB.Connection") OBJdbConnection.Open "AdvWorks" '创建并打开 Recordset 对象。 Set RsCustomerList = Server.CreateObject("ADODB.Recordset") RsCustomerList.ActiveConnection = OBJdbConnection RsCustomerList.CursorType = adOpenKeyset RsCustomerList.LockType = adLockOptimistic RsCustomerList.Source = "Customers" RsCustomerList.Open%> <!-- 如果这是第一次打开页面,则输入数据时 Form 集合将为空。 请运行 AddNew 方法--> <% If Not IsEmpty(Request.Form) Then If Not Request.Form("CompanyName") = "" Then RsCustomerList.AddNew RsCustomerList("CompanyName") = Request.Form("CompanyName") RsCustomerList("ContactLastName") = Request.Form("LastName") RsCustomerList("ContactFirstName") = Request.Form("FirstName") RsCustomerList("PhoneNumber") = Request.Form("PhoneNumber") RsCustomerList("City") = Request.Form("City") RsCustomerList("StateOrProvince") = Request.Form("State") RsCustomerList.Update RsCustomerList.MoveFirst End If End If %><TABLE COLSPAN=8 CELLPADDING=5 BORDER=0><!-- Customer 表的 BEGIN 列标头行--><TR><TD ALIGN=CENTER BGCOLOR="#008080"> <FONT STYLE="ARIAL NARROW" COLOR="#ffffff" SIZE=1>Company Name</FONT></TD> <TD ALIGN=CENTER BGCOLOR="#008080"> <FONT STYLE="ARIAL NARROW" COLOR="#ffffff" SIZE=1>Contact Name</FONT></TD> <TD ALIGN=CENTER WIDTH=150 BGCOLOR="#008080"> <FONT STYLE="ARIAL NARROW" COLOR="#ffffff" SIZE=1>Phone Number</FONT></TD> <TD ALIGN=CENTER BGCOLOR="#008080"> <FONT STYLE="ARIAL NARROW" COLOR="#ffffff" SIZE=1>City</FONT></TD> <TD ALIGN=CENTER BGCOLOR="#008080"> <FONT STYLE="ARIAL NARROW" COLOR="#ffffff" SIZE=1>State/Province</FONT></TD></TR> <!--每通过一遍记录集,显示一行 Customer 表的 ADO 数据--> <% Do While Not RsCustomerList.EOF %> <TR><TD BGCOLOR="f7efde" ALIGN=CENTER> <FONT STYLE="ARIAL NARROW" SIZE=1> <%= RSCustomerList("CompanyName")%> </FONT></TD> <TD BGCOLOR="f7efde" ALIGN=CENTER> <FONT STYLE="ARIAL NARROW" SIZE=1> <%= RScustomerList("ContactLastName") & ", " %> <%= RScustomerList("ContactFirstName") %> </FONT></TD> <TD BGCOLOR="f7efde" ALIGN=CENTER> <FONT STYLE="ARIAL NARROW" SIZE=1> <%= RScustomerList("PhoneNumber")%> </FONT></TD> <TD BGCOLOR="f7efde" ALIGN=CENTER> <FONT STYLE="ARIAL NARROW" SIZE=1> <%= RScustomerList("City")%> </FONT></TD> <TD BGCOLOR="f7efde" ALIGN=CENTER> <FONT STYLE="ARIAL NARROW" SIZE=1> <%= RScustomerList("StateOrProvince")%> </FONT></TD></TR> <!-- Next Row = Record Loop 并添加到行 html 表--> <% RScustomerList.MoveNext Loop %></TABLE><HR> <!-- 输入新记录的窗体将变量返回该页 --> <Table> <Form Method = Post Action="AddNew.asp" Name=Form> <TR><TD><P>Company Name:</TD> <TD><Input Type="Text" Size="50" Name="CompanyName" Value = ""></P></TD> <TR><TD><P>Contact First Name:</TD> <TD><Input Type="Text" Size="50" Name="FirstName" Value = ""></P></TD> <TR><TD><P>Contact Last Name:</TD> <TD><Input Type="Text" Size="50" Name="LastName" Value = ""></P></TD> <TR><TD><P>Contact Phone:</TD> <TD><Input Type="Text" Size="50" Name="PhoneNumber" Value = ""></P></TD> <TR><TD><P>City:</TD> <TD><Input Type="Text" Size="50" Name="City" Value = ""></P></TD> <TR><TD><P>State / Province:</TD> <TD><Input Type="Text" Size="5" Name="State" Value = ""></P></TD> <TR><TD><Input Type="Submit" Value="Add New "><Input Type="Reset" Value="Reset Form"> </Form></Table></Center></FONT> <%'Show location of DSN data source Response.Write(OBJdbConnection) %> <Script Language = "VBScript"> Sub Form_OnSubmit MsgBox "Sending New Record to Server",,"ADO-ASP _Example" End Sub </Script> </BODY></HTML>