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="새로 추가"> 
<input type="reset" value="취소">
</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") & "')"
에러 발생 시 다음으로 이동
conn.Execute sql,recaffected
if err<>0 then
  Response.Write("업데이트 권한이 없습니다!")
else 
  Response.Write("<h3>" & recaffected & " 레코드 추가됨</h3>")
end if
conn.close
%>
</body>
</html>

중요 사항

INSERT command 명령을 사용할 때 주의할 사항:

  • 테이블에 주键이 있으면, 주键 필드에 추가하는 값이 유일하고 비어 있지 않도록 하세요(아니라면 provider가 이 기록을 추가하지 않거나 오류가 발생할 수 있습니다)
  • 테이블에 자동 번호 필드가 있으면, INSERT 명령에서 이 필드를 포함하지 마세요(이 필드의 값은 provider가 책임합니다)

데이터 필드 없음에 대해

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

주의사항:모든 데이터베이스가 0 길이 문자열을 지원하지 않기 때문에, 공백 필드를 포함한 기록을 추가할 때 오류가 발생할 수 있습니다. 따라서, 사용하는 데이터베이스가 지원하는 데이터 타입을 확인하는 것이 중요합니다.