ADOレコードの追加
SQL INSERT INTOコマンドを使用して、データベース内のテーブルにレコードを追加できます。
データベースのテーブルにレコードを追加する
NorthwindデータベースのCustomersテーブルに新しいレコードを追加します。まず、データを収集するフィールドを含むフォームを作成します。
<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>
ユーザーが送信ボタンを押すと、フォームは「demo_add.asp」というファイルに送信されます。「demo_add.asp」ファイルには、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コマンドを使用する場合は、次の点に注意してください。
- テーブルに主キーが含まれている場合は、必ず一意のNull以外の値を主キーフィールドに追加してください(含まれていない場合、プロバイダーがレコードを追加しないか、エラーが発生する可能性があります)
- テーブルにAutoNumberフィールドが含まれている場合は、このフィールドをSQL INSERTコマンドに含めないでください(このフィールドの値はプロバイダーによって自動的に処理されます)
データのないフィールドはどうですか?
MS Accessデータベースでは、AllowZeroLengthプロパティをYesに設定すると、テキスト、ハイパーリンク、およびメモの各フィールドに長さゼロの文字列( "")を入力できます。
注:すべてのデータベースが長さゼロの文字列をサポートしているわけではなく、空白のフィールドを持つレコードが追加されるとエラーが発生する可能性があります。データベースがサポートするデータ型を確認することが重要です。