ADO 添加记录


我们可以使用 SQL INSERT INTO 命令向数据库的表中添加一条记录。


将记录添加到数据库的表中

我们想要向 Northwind 数据库的 Customers 表添加一条新记录。我们首先创建一个表单,其中包含我们要从中收集数据的字段:

<html>
<body>

<form method="post" action="demo_add.html">
<table>
<tr>
<td>CustomerID:</td>
<td><input name="custid"></td>
</tr><tr>
<td>Company Name:</td>
<td><input name="compname"></td>
</tr><tr>
<td>Contact Name:</td>
<td><input name="contname"></td>
</tr><tr>
<td>Address:</td>
<td><input name="address"></td>
</tr><tr>
<td>City:</td>
<td><input name="city"></td>
</tr><tr>
<td>Postal Code:</td>
<td><input name="postcode"></td>
</tr><tr>
<td>Country:</td>
<td><input name="country"></td>
</tr>
</table>
<br><br>
<input type="submit" value="Add New">
<input type="reset" value="Cancel">
</form>

</body>
</html>


当用户按下提交按钮时,表单将发送到名为"demo_add.html" 的文件。 "demo_add.html" 文件包含将新记录添加到 Customers 表的代码:

<html>
<body>

<%
set conn=Server.CreateObject("ADODB.Connection")
conn.Provider="Microsoft.Jet.OLEDB.4.0"
conn.Open "c:/webdata/northwind.mdb"

sql="INSERT INTO customers (customerID,companyname,"
sql=sql & "contactname,address,city,postalcode,country)"
sql=sql & " VALUES "
sql=sql & "('" & Request.Form("custid") & "',"
sql=sql & "'" & Request.Form("compname") & "',"
sql=sql & "'" & Request.Form("contname") & "',"
sql=sql & "'" & Request.Form("address") & "',"
sql=sql & "'" & Request.Form("city") & "',"
sql=sql & "'" & Request.Form("postcode") & "',"
sql=sql & "'" & Request.Form("country") & "')"

on error resume next
conn.Execute sql,recaffected
if err<>0 then
  Response.Write("No update permissions!")
else
  Response.Write("<h3>" & recaffected & " record added</h3>")
end if
conn.close
%>

</body>
</html>

重要的

如果您使用 SQL INSERT 命令,请注意以下事项:

  • 如果表包含主键,请确保将唯一的非空值附加到主键字段(如果没有,提供程序可能不会附加记录,否则会发生错误)
  • 如果表包含自动编号字段,请勿在 SQL INSERT 命令中包含此字段(此字段的值将由提供程序自动处理)

没有数据的字段怎么办?

在 MS Access 数据库中,如果将“AllowZeroLength”属性设置为“是”,则可以在“文本”、“超链接”和“备注”字段中输入零长度字符串 ("")。

笔记:并非所有数据库都支持零长度字符串,并且在添加具有空白字段的记录时可能会导致错误。检查您的数据库支持哪些数据类型非常重要。