Neueste Web-Entwicklung Tutorials
 

In ADO Datensätze


Wir können die SQL INSERT INTO-Befehl verwenden, um einen Datensatz zu einer Tabelle in einer Datenbank hinzuzufügen.


Fügen Sie einen Datensatz einer Tabelle in einer Datenbank

Wir wollen einen neuen Datensatz in der Customers-Tabelle in der Northwind-Datenbank hinzuzufügen. Zuerst erstellen wir eine Form, die die Felder, die wir aus Daten sammeln möchten enthält:

<html>
<body>

<form method="post" action="demo_add.asp">
<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>

Wenn der Benutzer die Submit - Button drückt , wird das Formular in eine Datei namens gesendet "demo_add.asp" . Die "demo_add.asp" Datei enthält den Code, um einen neuen Datensatz der Tabelle Customers hinzufügen wird:

<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>

Wichtig

Wenn Sie den SQL-Befehl INSERT der folgenden bewusst sein, verwenden:

  • Wenn die Tabelle einen Primärschlüssel enthält, stellen Sie sicher, eine einzigartige, nicht-Null-Wert an den Primärschlüsselfeld anhängen (falls nicht, kann der Anbieter nicht den Datensatz anhängen, oder ein Fehler auftritt)
  • Wenn die Tabelle ein Autowert-Feld enthält, nicht enthalten dieses Feld in der SQL-Befehl INSERT (der Wert dieses Feldes kümmert sich automatisch vom Anbieter getroffen werden)

Was über Felder ohne Daten?

In einer MS Access - Datenbank können Sie leere Zeichenfolge eingeben ("") in Text, Hyperlink, und Memo - Feldern Wenn Sie die AllowZeroLength - Eigenschaft auf Ja festgelegt.

Note: Nicht alle Datenbanken leere Zeichenfolgen unterstützen und kann einen Fehler verursachen , wenn ein Datensatz mit leeren Feldern hinzugefügt wird. Es ist wichtig zu überprüfen, welche Datentypen der Datenbank unterstützt.