HOWTO: Visual C# .NET을 사용하여 DataSet 개체에서 데이터베이스 업데이트

기술 자료 번역 기술 자료 번역
기술 자료: 307587 - 이 문서가 적용되는 제품 보기.
이 문서는 이전에 다음 ID로 출판되었음: KR307587
모두 확대 | 모두 축소

이 페이지에서

요약

Microsoft .NET Framework에서 데이터 액세스의 핵심 요소인 DataSet 개체는 테이블, 보기 및 관계를 보관할 수 있는 메모리 내 개체입니다. 본 문서에서는 데이터가 포함된 DataSet을 데이터베이스에서 로드하고 데이터를 수정한 다음 데이터베이스로 되돌려 보내서 원본을 업데이트하는 방법을 보여줍니다.

요구 사항

다음은 권장 하드웨어, 소프트웨어, 네트워크 인프라 및 서비스 팩입니다.
  • Microsoft Windows 2000 Professional, Microsoft Windows 2000 Server, Microsoft Windows 2000 Advanced Server 또는 Microsoft Windows NT 4.0 Server
  • Microsoft SQL Server 버전 7.0, Microsoft SQL Server 2000 또는 Microsoft Data Engine(MSDE) - PUBS 예제 데이터베이스 설치
  • Microsoft Visual Studio .NET
본 문서는 다음 항목에 대해 잘 알고 있는 사용자를 대상으로 합니다.
  • 데이터베이스 용어
  • 구조적 쿼리 언어(SQL)

DataSet 개체에서 데이터베이스를 업데이트하는 방법

이 절에서는 DataSet 개체를 사용하여 데이터베이스 내의 데이터를 업데이트하는 방법을 보여줍니다. 또한 SqlCommand 개체를 사용하여 데이터를 데이터베이스에 직접 삽입, 업데이트 및 삭제할 수 있습니다.

이 문서를 이해하는 데 도움이 필요할 경우 Microsoft 기술 자료의 다음 문서를 참조하십시오.
  • 314145 HOW TO: Populate a DataSet Object from a Database Using Visual C# .NET
314145에는 DataSet이 데이터베이스와 어떻게 다른지와 데이터베이스에서 데이터를 검색하여 DataSet에 로드하는 방법 등이 설명되어 있습니다.

DataSet이 로드된 후에 데이터를 수정할 수 있습니다. DataSet은 이러한 변경을 추적합니다. DataSet 개체는 데이터베이스에서 검색된 데이터의 메모리 내 캐시로 간주할 수 있습니다. DataSet 개체는 테이블, 관계 및 제약 조건의 집합으로 이루어집니다.

DataSet을 업데이트하고 업데이트한 내용을 데이터베이스로 되돌려 보내려면 다음 절차를 수행하십시오.
  1. Microsoft Visual Studio .NET을 엽니다.
  2. Visual C# .NET에서 새 콘솔 응용 프로그램을 만듭니다. 기본적으로 Visual Studio는 정적 클래스와 빈 Main() 프로시저를 만듭니다.
  3. SystemSystem.Data 네임스페이스에 대한 참조가 프로젝트에 포함되어 있는지 확인합니다. System, System.DataSystem.Data.SqlClient 네임스페이스에 using 문을 사용합니다. 그러면 나중에 코드에서 이 네임스페이스의 선언을 한정하지 않아도 됩니다. 이 명령문은 항상 선언 앞에 사용해야 합니다.
    using System;
    using System.Data;
    using System.Data.SqlClient;
  4. 데이터를 수정하고 변경 사항을 데이터베이스로 다시 제출하기 전에 정보를 DataSet으로 로드해야 합니다. 자세한 절차는 314145를 참조하십시오. 이 단계에서는 불필요한 중복을 피하기 위해 코드를 자세하게 소개하지 않습니다.

    다음 코드의 연결 문자열은 'sa' 계정에 대해 빈 암호를 갖는 로컬 컴퓨터(또는 코드가 실행되고 있는 컴퓨터) 상의 SQL Server를 가리킵니다. 필요하면 이 문자열을 사용자 고유의 설정에 맞게 바꾸십시오. 간단히 말해서 연결이 만들어진 다음 데이터 어댑터가 만들어집니다. 데이터 어댑터는 DataSet을 데이터로 채우는 데 사용됩니다.
    string sConnectionString;
    
    // Modify the following string to correctly connect to your SQL Server.
    sConnectionString = "Password=;User ID=sa;"
    	+ "Initial Catalog=pubs;"
    	+ "Data Source=(local)";
    
    SqlConnection objConn
    	= new SqlConnection(sConnectionString);
    objConn.Open();
    
    // Create an instance of a DataAdapter.
    SqlDataAdapter daAuthors 
    	= new SqlDataAdapter("Select * From Authors", objConn);
    
    // Create an instance of a DataSet, and retrieve data from the Authors table.
    DataSet dsPubs = new DataSet("Pubs");
    daAuthors.FillSchema(dsPubs,SchemaType.Source, "Authors");
    daAuthors.Fill(dsPubs,"Authors");
  5. 이제 데이터가 로드되었으므로 데이터를 수정할 수 있습니다. 다양한 방법으로 행이나 레코드를 추가할 수 있습니다. 이 코드 예제에서는 다음 3단계 절차를 사용합니다.
      • DataTable에서 새 DataRow 개체를 가져옵니다.
      • DataRow 필드 값을 필요한 값으로 설정합니다.
      • DataTable.Rows 컬렉션의 Add 메서드에 새 개체를 전달합니다.

    4단계에 나와 있는 코드 뒤에 다음 코드를 붙여넣습니다.
    //****************
    // BEGIN ADD CODE 
    // Create a new instance of a DataTable.
    DataTable tblAuthors;
    tblAuthors = dsPubs.Tables["Authors"];
    
    DataRow drCurrent;
    // Obtain a new DataRow object from the DataTable.
    drCurrent = tblAuthors.NewRow();
    
    // Set the DataRow field values as necessary.
    drCurrent["au_id"] = "993-21-3427";
    drCurrent["au_fname"] = "George";
    drCurrent["au_lname"] = "Johnson";
    drCurrent["phone"] = "800 226-0752";
    drCurrent["address"] = "1956 Arlington Pl.";
    drCurrent["city"] = "Winnipeg";
    drCurrent["state"] = "MB";
    drCurrent["contract"] = 1;
    
    // Pass that new object into the Add method of the DataTable.
    tblAuthors.Rows.Add(drCurrent);
    Console.WriteLine("Add was successful, Click any key to continue!!");
    Console.ReadLine();
    
    // END ADD CODE  
  6. 4단계에 나와 있는 코드 뒤에 다음 코드를 붙여넣습니다. 기존 행을 편집하려면 적절한 DataRow 개체를 가져온 다음 하나 이상의 열에 대해 새 값을 지정합니다. 먼저 올바른 행을 찾아야 하는데, 데이터뿐 아니라 테이블의 스키마도 로드했기 때문에(4단계의 FillSchema 호출) 휠씬 쉽게 수행할 수 있습니다. 스키마가 올바른 위치에 있으면 기본 키에 해당하는 열이 테이블에 알려지고 Rows 컬렉션의 Find 메서드를 사용할 수 있게 됩니다.

    Find 메서드는 특정한 기본 키 값(이 예제의 경우, au_id)을 갖는 DataRow 개체를 반환합니다. 이러한 DataRow가 반환된 후에는 열을 수정할 수 있습니다. BeginEditEndEdit에서 수정 내용을 줄 바꿈할 필요는 없지만, 이렇게 하면 DataSet이 수행해야 하는 작업이 간단해지며 EndEdit가 호출될 때 DataSet이 동시에 유효성 확인 작업을 수행할 수 있습니다. ADD 코드 뒤에 다음 코드를 붙여넣습니다.
    //*****************
    // BEGIN EDIT CODE 
    
    drCurrent = tblAuthors.Rows.Find("213-46-8915");
    drCurrent.BeginEdit();
    drCurrent["phone"] = "342" + drCurrent["phone"].ToString().Substring(3);
    drCurrent.EndEdit();
    Console.WriteLine("Record edited successfully, Click any key to continue!!");
    Console.ReadLine();
    
    // END EDIT CODE  
  7. 4단계에 나와 있는 코드 뒤에 다음 코드를 붙여넣습니다. 모든 변경 내용을 적용하여 원본 데이터베이스를 업데이트하려면 DataAdapter 개체의 Update 메서드에 DataSet을 전달합니다.

    단, Update를 호출하기 전에 DataAdapter 개체의 InsertCommand, UpdateCommandDeleteCommand 속성을 설정해야 합니다. SQL을 수동으로 쓰고 해당하는 SqlCommand 개체를 사용하여 세 가지 속성을 채울 수 있지만, Visual Studio .NET을 사용하여 세 가지 명령을 자동으로 생성할 수도 있습니다.

    필요한 명령을 생성하려면 SqlCommandBuilder 개체의 인스턴스를 만들고 생성자에서 DataAdapter를 사용해야 합니다. 다음 코드 예제에 설명된 이 방법을 사용하려면 테이블에 사용할 수 있는 기본 키 정보가 필요합니다. 기본 키 정보에 액세스하려면 FillSchema를 호출한 다음 DataAdapterMissingSchemaAction 속성을 AddWithKey로 설정하거나 코드에서 기본 키를 수동으로 설정합니다. EDIT 코드 뒤에 다음 코드를 붙여넣습니다.
    //*****************
    // BEGIN SEND CHANGES TO SQL SERVER 
    
    SqlCommandBuilder objCommandBuilder = new SqlCommandBuilder(daAuthors);
    daAuthors.Update(dsPubs, "Authors");
    Console.WriteLine("SQL Server updated successfully, Check Server explorer to see changes");
    Console.ReadLine();
    
    // END SEND CHANGES TO SQL SERVER
  8. 4단계에 나와 있는 코드 뒤에 다음 코드를 붙여넣습니다. 행을 완전히 삭제하려면 DataRow 개체의 Delete 메서드를 사용합니다. Rows 컬렉션에는 RemoveRemoveAt의 두 메서드가 포함되어 있는데, 이들 메서드는 행을 삭제하는 것처럼 보이지만 실제로는 컬렉션에서 행을 제거하기만 합니다. 삭제 내용을 원본 데이터베이스에 돌려보내는 것은 Delete 메서드뿐입니다. SEND CHANGES TO SQL SERVER 코드 뒤에 다음 코드를 붙여넣습니다.
    //*****************
    //BEGIN DELETE CODE 
    
    drCurrent = tblAuthors.Rows.Find("993-21-3427");
    drCurrent.Delete();
    Console.WriteLine("Record deleted successfully, Click any key to continue!!"); 
    Console.ReadLine();
    
    //END DELETE CODE 
  9. 4단계에 나와 있는 코드 뒤에 다음 코드를 붙여넣습니다. 변경 내용을 SQL Server로 보내어 앞서 추가한 레코드를 제거합니다. DELETE 코드 뒤에 다음 코드를 붙여넣습니다.
    //*****************
    // CLEAN UP SQL SERVER
    daAuthors.Update(dsPubs, "Authors");
    Console.WriteLine("SQL Server updated successfully, Check Server explorer to see changes");
    Console.ReadLine();
  10. 4단계에 나와 있는 코드 뒤에 다음 코드를 붙여넣습니다. 프로젝트를 저장합니다.
  11. 4단계에 나와 있는 코드 뒤에 다음 코드를 붙여넣습니다. 디버그 메뉴에서 시작을 눌러 프로젝트를 실행합니다. 코드가 처리되는 동안 코드 진행률을 나타내고 데이터의 현재 상태를 검토할 수 있는 여러 메시지 상자가 나타납니다.

전체 코드 예제

using System;
using System.Data;
using System.Data.SqlClient;

namespace PopulateDataSet
{

    /// <summary>
    /// Summary description for Class1.
    /// </summary>
    class Class1
    {
        static void Main(string[] args)
        {
            string sConnectionString;

            // Modify the following string to correctly connect to your SQL Server.
            sConnectionString = "Password=;User ID=sa;"
                + "Initial Catalog=pubs;"
                + "Data Source=(local)";

            SqlConnection objConn
                = new SqlConnection(sConnectionString);
            objConn.Open();

            // Create an instance of a DataAdapter.
            SqlDataAdapter daAuthors 
                = new SqlDataAdapter("Select * From Authors", objConn);

            // Create an instance of a DataSet, and retrieve 
            // data from the Authors table.
            DataSet dsPubs = new DataSet("Pubs");
            daAuthors.FillSchema(dsPubs,SchemaType.Source, "Authors");
            daAuthors.Fill(dsPubs,"Authors"); 
            //****************
            // BEGIN ADD CODE 
            // Create a new instance of a DataTable.
            DataTable tblAuthors;
            tblAuthors = dsPubs.Tables["Authors"];

            DataRow drCurrent;
            // Obtain a new DataRow object from the DataTable.
            drCurrent = tblAuthors.NewRow();

            // Set the DataRow field values as necessary.
            drCurrent["au_id"] = "993-21-3427";
            drCurrent["au_fname"] = "George";
            drCurrent["au_lname"] = "Johnson";
            drCurrent["phone"] = "800 226-0752";
            drCurrent["address"] = "1956 Arlington Pl.";
            drCurrent["city"] = "Winnipeg";
            drCurrent["state"] = "MB";
            drCurrent["contract"] = 1;

            // Pass that new object into the Add method of the DataTable.
            tblAuthors.Rows.Add(drCurrent);
            Console.WriteLine("Add was successful, Click any key to continue!!");
            Console.ReadLine();

            // END ADD CODE   
            //*****************
            // BEGIN EDIT CODE 

            drCurrent = tblAuthors.Rows.Find("213-46-8915");
            drCurrent.BeginEdit();
            drCurrent["phone"] = "342" + drCurrent["phone"].ToString().Substring(3);
            drCurrent.EndEdit();
            Console.WriteLine("Record edited successfully, Click any key to continue!!");
            Console.ReadLine();
			
            // END EDIT CODE   
            //*****************
            // BEGIN SEND CHANGES TO SQL SERVER 

            SqlCommandBuilder objCommandBuilder = new SqlCommandBuilder(daAuthors);
            daAuthors.Update(dsPubs, "Authors");
            Console.WriteLine("SQL Server updated successfully, Check Server explorer to see changes");
            Console.ReadLine();
			
            // END SEND CHANGES TO SQL SERVER 
            //*****************
            //BEGIN DELETE CODE 

            drCurrent = tblAuthors.Rows.Find("993-21-3427");
            drCurrent.Delete();
            Console.WriteLine("SRecord deleted successfully, Click any key to continue!!"); 
            Console.ReadLine();
       
            //END DELETE CODE  
            //*****************
            // CLEAN UP SQL SERVER
            daAuthors.Update(dsPubs, "Authors");
            Console.WriteLine("SQL Server updated successfully, Check Server explorer to see changes");
            Console.ReadLine();         	
			
        }
    }
}

참조

ADO.NET, DataSet 개체 및 SQL 사용에 대한 자세한 내용은 다음 Microsoft 웹 사이트를 참조하십시오.
"Diving into Data Access"(MSDN Voices 칼럼)
http://msdn.microsoft.com/columns/

"ADO.NET for the ADO Programmer"
http://msdn2.microsoft.com/en-us/library/ms973217.aspx

MSDN Online .NET Developer Center
http://msdn.microsoft.com/net

속성

기술 자료: 307587 - 마지막 검토: 2007년 3월 19일 월요일 - 수정: 2.1
본 문서의 정보는 다음의 제품에 적용됩니다.
  • Microsoft Visual C# .NET 2002 Standard Edition
키워드:?
kbhowto kbhowtomaster kbgrpdsvbdb KB307587

피드백 보내기

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com