ADO Voeg rekords by


Ons kan die SQL INSERT INTO-opdrag gebruik om 'n rekord by 'n tabel in 'n databasis te voeg. 


Voeg 'n rekord by 'n tabel in 'n databasis

Ons wil 'n nuwe rekord by die Customers-tabel in die Northwind-databasis voeg. Ons skep eers 'n vorm wat die velde bevat waaruit ons data wil insamel:

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


Wanneer die gebruiker die indien-knoppie druk, word die vorm na 'n lêer genaamd "demo_add.asp" gestuur. Die "demo_add.asp"-lêer bevat die kode wat 'n nuwe rekord by die Kliënte-tabel sal voeg:

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

Belangrik

As jy die SQL INSERT-opdrag gebruik, wees bewus van die volgende:

  • As die tabel 'n primêre sleutel bevat, maak seker dat jy 'n unieke, nie-Nul-waarde by die primêre sleutelveld voeg (indien nie, sal die verskaffer dalk nie die rekord byvoeg nie, of 'n fout kom voor)
  • As die tabel 'n outonommer-veld bevat, moenie hierdie veld by die SQL INSERT-opdrag insluit nie (die waarde van hierdie veld sal outomaties deur die verskaffer versorg word)

Wat van velde sonder data?

In 'n MS Access-databasis kan jy nullengte-stringe ("") in Teks-, Hiperskakel- en Memo-velde invoer AS jy die AllowZeroLength-eienskap op Ja stel.

Let wel: Nie alle databasisse ondersteun nullengte-stringe nie en kan 'n fout veroorsaak wanneer 'n rekord met leë velde bygevoeg word. Dit is belangrik om te kyk watter datatipes jou databasis ondersteun.