最新のWeb開発のチュートリアル
 

ADOのレコードを追加します。


私たちは、データベース内のテーブルにレコードを追加するには、コマンドINTO SQLのINSERTを使用することができます。


データベース内のテーブルにレコードを追加

私たちは、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値を追加することを確認してください
  • テーブルがオートナンバー型フィールドが含まれている場合は、SQLのINSERTコマンドで、このフィールドが含まれていません(このフィールドの値は、プロバイダによって自動的に世話をされます)

どのようなデータのないフィールドについてはどうですか?

MS Accessデータベースでは、長さゼロの文字列を入力することができます("")あなたがYesにAllowZeroLengthプロパティを設定する場合は、テキスト、ハイパーリンク、およびメモフィールドでを。

Note:必ずしもすべてのデータベースが長さゼロの文字列をサポートし、空白のフィールドを持つレコードが追加されたときにエラーが発生することがあります。 あなたのデータベースがサポートしているデータの種類を確認することが重要です。