ADO dodać
Możemy użyć INSERT INTO polecenia SQL, aby dodać rekordy do tabeli bazy danych.
Aby dodać rekord w tabeli bazy danych
Chcemy, aby dodać nowy rekord do tabeli Klienci w bazie danych Northwind. Najpierw chcemy stworzyć postać, forma zawiera dane, które chcemy zebrać pól wejściowych:
<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>
Gdy użytkownik naciśnie przycisk OK, formularz zostanie przesłany do pliku o nazwie "demo_add.asp" z. Plik "demo_add.asp" może zawierać kod, aby dodać nowy rekord do tabeli Klienci:
<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>
WAŻNE
Podczas korzystania z komend INSERT, należy zwrócić uwagę na następujące elementy:
- Jeśli tabela zawiera klucz podstawowy, upewnij się, aby dodać wartość do pola klucza podstawowego jest wyjątkowy i nie jest pusty (inaczej, Dostawca nie będzie dołączyć rekordy, lub że wystąpi błąd)
- Jeśli tabela zawiera pole Autonumerowanie, nie wiążą się z tą dziedziną w poleceniu INSERT (wartość pola jest określana przez dostawcę odpowiedzialnej)
Brak danych na polu
W bazie danych MS Access, jeśli ustawisz właściwość AllowZeroLength jest ustawiona na "Tak", można tekst, hiperłącza i zauważa, pole, aby wprowadzić ciąg znaków o zerowej długości ( "").
Uwaga: Nie wszystkie bazy danych obsługują zerowej długości łańcucha, co może spowodować wystąpienie błędu podczas dodawania rekordów z pustymi polami. Więc sprawdzić, czy przy użyciu typów danych bazy danych obsługiwana jest bardzo ważne.