최신 웹 개발 튜토리얼
 

ADO 레코드 추가


우리는 데이터베이스의 테이블에 레코드를 추가 할 명령에 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" 파일은 고객 테이블에 새 레코드를 추가 할 코드가 포함되어 있습니다 :

<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 명령을 사용하는 경우 다음 사항에 유의 :

  • 테이블에 기본 키가 포함되어있는 경우 (없는 경우, 공급자가 레코드를 추가하지 않을 수 있습니다 또는 오류가 발생합니다) 기본 키 필드에 고유 비 - 널 값을 추가해야합니다
  • 테이블에 일련 번호 필드를 포함하는 경우, SQL의 INSERT 명령이 필드를 포함하지 않습니다 (이 필드의 값은 제공자에 의해 자동적으로 처리 될 것입니다)

어떤 데이터가없는 필드에 대한?

석사 Access 데이터베이스에서는 길이 제로의 문자열을 입력 할 수 있습니다 ("") Yes (예)로 AllowZeroLength 속성을 설정하면 텍스트, 하이퍼 링크 및 메모 필드에 있습니다.

Note: 모든 데이터베이스 길이가 0 인 문자열을 지원하고 빈 필드가있는 레코드를 추가 할 때 오류가 발생할 수 있습니다. 당신의 데이터베이스가 지원하는 데이터 유형을 확인하는 것이 중요하다.