내보내기(0) 인쇄
모두 확장
이 문서는 기계로 번역한 것입니다. 원본 텍스트를 보려면 포인터를 문서의 문장 위로 올리십시오. 추가 정보
번역
원본

ObjectDataSource.DeleteParameters 속성

DeleteMethod 메서드에서 사용하는 매개 변수가 포함된 매개 변수 컬렉션을 가져옵니다.

네임스페이스:  System.Web.UI.WebControls
어셈블리:  System.Web(System.Web.dll)

[PersistenceModeAttribute(PersistenceMode.InnerProperty)]
public ParameterCollection DeleteParameters { get; }

속성 값

형식: System.Web.UI.WebControls.ParameterCollection
DeleteMethod 메서드에서 사용하는 매개 변수가 포함된 ParameterCollection입니다.

DeleteParameters 컬렉션에 포함된 매개 변수의 이름과 형식은 DeleteMethod 메서드 시그니처에 포함된 매개 변수의 이름 및 형식과 일치해야 합니다. 매개 변수 이름은 OldValuesParameterFormatString 속성의 영향을 받으며 대/소문자를 구분합니다. 컬렉션의 매개 변수는 데이터 바인딩된 컨트롤에 있는 데이터, 선언적으로 지정된 매개 변수 및 프로그래밍 방식으로 추가된 매개 변수에 따라 결정됩니다. 자세한 내용은 DeleteUsing Parameters with the ObjectDataSource Control의 "매개 변수 병합"을 참조하십시오.

DeleteParameters 속성은 ObjectDataSource 컨트롤과 연결된 ObjectDataSourceView 개체에 포함된 DeleteParameters 속성을 검색합니다.

매개 변수 병합, 개체 수명 및 메서드 확인에 대한 자세한 내용은 DeleteMethod를 참조하십시오.

이 단원에는 두 개의 코드 예제가 있습니다. 첫 번째 코드 예제에서는 비즈니스 개체를 가진 ObjectDataSource 개체와 GridView 컨트롤을 사용하여 데이터를 삭제하는 방법을 보여 줍니다. 두 번째 코드 예제에서는 첫 번째 코드 예제에서 사용된 EmployeeLogic 클래스를 보여 줍니다.

다음 코드 예제에서는 비즈니스 개체를 가진 ObjectDataSource 컨트롤의 DeleteParameters 속성과 GridView 컨트롤을 사용하여 데이터를 삭제하는 방법을 보여 줍니다. GridView 컨트롤은 처음에 EmployeeLogic 개체에서 데이터를 검색하기 위해 SelectMethod 속성에 의해 지정된 메서드를 사용하여 모든 직원의 집합을 표시합니다. AutoGenerateDeleteButton 속성이 true로 설정되어 있기 때문에 GridView 컨트롤은 자동으로 삭제 단추를 표시합니다.

삭제 단추를 클릭하면 Deleting 이벤트가 두 개의 매개 변수와 함께 호출됩니다. 한 매개 변수는 DataGrid 컨트롤에서 가져온 EmpID이며 DataKeyNames 속성을 기반으로 합니다. 다른 매개 변수는 선언적 DeleteParameters 속성에서 가져옵니다. EmployeeLogic 클래스는 DeleteEmployee 메서드를 오버로드합니다. 한 오버로드는 NorthwindEmployee 매개 변수를 사용하고 다른 오버로드는 anID라는 Int32 매개 변수를 사용합니다. Deleting 이벤트에서 InputParameters 속성의 항목은 original_EmpID에서 가져온 anID라는 이름의 매개 변수 하나만 포함하도록 조정됩니다. 이벤트 처리기가 종료되면 일치하는 DeleteEmployee 메서드가 호출됩니다.

다음 코드 예제에서는 DataGrid 컨트롤을 표시하고 Deleting 이벤트를 처리하는 웹 페이지를 보여 줍니다.


<%@ Register TagPrefix="aspSample" Namespace="Samples.AspNet.CS" Assembly="Samples.AspNet.CS" %>
<%@ Import namespace="Samples.AspNet.CS" %>
<%@ Page language="c#" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
private void NorthwindEmployeeDeleting(object source, ObjectDataSourceMethodEventArgs e)
{
  IDictionary paramsFromPage = e.InputParameters;

  paramsFromPage.Remove("anID");
  paramsFromPage.Add("anID", (int)paramsFromPage["EmpID"]);
  paramsFromPage.Remove("EmpID");

}
</script>

<html xmlns="http://www.w3.org/1999/xhtml" >
  <head>
    <title>ObjectDataSource - C# Example</title>
  </head>
  <body>
    <form id="Form1" method="post" runat="server">

        <asp:gridview
          id="GridView1"
          runat="server"
          datasourceid="ObjectDataSource1"
          autogeneratedeletebutton="true"
          DataKeyNames="EmpID">
        </asp:gridview>

        <asp:objectdatasource
          id="ObjectDataSource1"
          runat="server"
          selectmethod="GetAllEmployees"
          deletemethod="DeleteEmployee"
          OnDeleting="NorthwindEmployeeDeleting"
          typename="Samples.AspNet.CS.EmployeeLogic">
          <deleteparameters>
            <asp:parameter name="anID" type="Int32" />
          </deleteparameters>
        </asp:objectdatasource>

    </form>
  </body>
</html>


다음 코드 예제에서는 이전 코드 예제에서 사용된 EmployeeLogic 클래스를 보여 줍니다.


namespace Samples.AspNet.CS {

using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.Web.UI;
using System.Web.UI.WebControls;
  //
  // EmployeeLogic is a stateless business object that encapsulates
  // the operations you can perform on a NorthwindEmployee object.
  //
  public class EmployeeLogic {

    // Returns a collection of NorthwindEmployee objects.
    public static ICollection GetAllEmployees () {
      ArrayList al = new ArrayList();

      // Use the SqlDataSource class to wrap the
      // ADO.NET code required to query the database.
      ConnectionStringSettings cts = ConfigurationManager.ConnectionStrings["NorthwindConnection"];

      SqlDataSource sds
        = new SqlDataSource(cts.ConnectionString,
                            "SELECT EmployeeID FROM Employees");
      try {
        IEnumerable IDs = sds.Select(DataSourceSelectArguments.Empty);

        // Iterate through the Enumeration and create a
        // NorthwindEmployee object for each ID.
        IEnumerator enumerator = IDs.GetEnumerator();
        while (enumerator.MoveNext()) {
          // The IEnumerable contains DataRowView objects.
          DataRowView row = enumerator.Current as DataRowView;
          int id = (int) row["EmployeeID"];
          NorthwindEmployee nwe = new NorthwindEmployee(id);
          // Add the NorthwindEmployee object to the collection.
          al.Add(nwe);
        }
      }
      finally {
        // If anything strange happens, clean up.
        sds.Dispose();
      }

      return al;
    }

    public static NorthwindEmployee GetEmployee(int anID) {
      return new NorthwindEmployee(anID);
    }

    public static void DeleteEmployee(NorthwindEmployee ne) {
      bool retval = ne.Delete();
      if (! retval) { throw new NorthwindDataException("Employee delete failed."); }
      // Delete the object in memory.
      ne = null;
    }

    public static void DeleteEmployee(int anID) {
        NorthwindEmployee tempEmp = new NorthwindEmployee(anID);
        DeleteEmployee(tempEmp);
    }
  }
  public class NorthwindEmployee {

    public NorthwindEmployee (int anID) {
      this.ID = anID;

      ConnectionStringSettings cts = ConfigurationManager.ConnectionStrings["NorthwindConnection"];
      SqlConnection conn = new SqlConnection (cts.ConnectionString);
      SqlCommand sc =
        new SqlCommand(" SELECT FirstName,LastName " +
                       " FROM Employees " +
                       " WHERE EmployeeID = @empId",
                       conn);
      // Add the employee ID parameter and set its value.
      sc.Parameters.Add(new SqlParameter("@empId",SqlDbType.Int)).Value = Int32.Parse(anID.ToString());
      SqlDataReader sdr = null;

      try {
        conn.Open();
        sdr = sc.ExecuteReader();

        // This is not a while loop. It only loops once.
        if (sdr != null && sdr.Read()) {
          // The IEnumerable contains DataRowView objects.
          this.firstName        = sdr["FirstName"].ToString();
          this.lastName         = sdr["LastName"].ToString();
        }
        else {
          throw new NorthwindDataException("Data not loaded for employee id.");
        }
      }
      finally {
        try {
          if (sdr != null) sdr.Close();
          conn.Close();
        }
        catch (SqlException) {
          // Log an event in the Application Event Log.
          throw;
        }
      }
    }

    private object ID;
    public object EmpID {
      get { return ID; }
    }

    private string lastName;
    public string LastName {
      get { return lastName; }
      set { lastName = value; }
    }

    private string firstName;
    public string FirstName {
      get { return firstName; }
      set { firstName = value;  }
    }
    public bool Delete () {
      if (ID.Equals(DBNull.Value)) {
        // The Employee object is not persisted.
        return true;
      }
      else {
        // The Employee object is persisted.
        // Use the SqlDataSource control as a convenient wrapper for
        // the ADO.NET code needed to delete a record from the database.
        ConnectionStringSettings cts = ConfigurationManager.ConnectionStrings["NorthwindConnection"];
        SqlDataSource sds = new SqlDataSource();
        try {
          sds.ConnectionString = cts.ConnectionString;
          sds.DeleteCommand = "DELETE FROM Employees WHERE EmployeeID=@empID;";
          sds.DeleteParameters.Add(new Parameter("empID",TypeCode.Int32,this.ID.ToString()));

          /* To make this sample fully functional, uncomment these lines
          int retval = sds.Delete();
          if (retval == 1) { return true; }
          return false; */

          return true;
        }
        finally {
          sds.Dispose();
        }
      }
    }
  }
  internal class NorthwindDataException: Exception {
    public NorthwindDataException(string msg) : base (msg) { }
  }
}


.NET Framework

4.5.2, 4.5.1, 4.5, 4, 3.5, 3.0, 2.0에서 지원

Windows Phone 8.1, Windows Phone 8, Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008(서버 코어 역할은 지원되지 않음), Windows Server 2008 R2(서버 코어 역할은 SP1 이상에서 지원, Itanium은 지원되지 않음)

.NET Framework에서 모든 플랫폼의 전체 버전을 지원하지는 않습니다. 지원되는 버전의 목록을 보려면 .NET Framework 시스템 요구 사항을 참조하십시오.

커뮤니티 추가 항목

추가
표시:
© 2014 Microsoft