기본 콘텐츠로 건너뛰기

[C#][DB][ADO.NET] SqlCommand

public partial class Form1 : Form
    {
        string strConn = "server=.\\SQLEXPRESS;database=example;uid=sa;pwd=12345";
        SqlConnection Conn;
        SqlDataAdapter dataAdapter;
        DataSet dataSet;

        public Form1()
        {
            InitializeComponent();
        }

        private void SqlCommandInit()
        {
            string strSelectSQL = "SELECT * FROM tblEx01";
            dataAdapter.SelectCommand = new SqlCommand(strSelectSQL, Conn);         

            string strInsertCommand = "INSERT INTO tblEx01 (name, age) VALUES (@name, @age)";
            dataAdapter.InsertCommand = new SqlCommand(strInsertCommand, Conn);
            dataAdapter.InsertCommand.Parameters.Add("@name", SqlDbType.NVarChar, 15, "name");
            dataAdapter.InsertCommand.Parameters.Add("@age", SqlDbType.Int, 0, "age");

            string strDeleteCommand = "DELETE FROM tblEx01 WHERE id = @id";
            dataAdapter.DeleteCommand = new SqlCommand(strDeleteCommand, Conn);
            dataAdapter.DeleteCommand.Parameters.Add("@id", SqlDbType.Int, 0, "id");

            string strUpdateCommand = "UPDATE tblEx01 SET name = @name, age = @age WHERE id = @id";
            dataAdapter.UpdateCommand = new SqlCommand(strUpdateCommand, Conn);
            dataAdapter.UpdateCommand.Parameters.Add("@name", SqlDbType.NVarChar, 20, "name");
            dataAdapter.UpdateCommand.Parameters.Add("@age", SqlDbType.Int, 0, "age");
            dataAdapter.UpdateCommand.Parameters.Add("@id", SqlDbType.Int, 0, "id");         
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            Conn = new SqlConnection(strConn);
            dataAdapter = new SqlDataAdapter();         
            dataSet = new DataSet();       

            SqlCommandInit();
            dataAdapter.Fill(dataSet, "tblEx01");
            dataGridView1.DataSource = dataSet.Tables["tblEx01"];
        }
        // 입력
        private void button1_Click(object sender, EventArgs e)
        {
            dataSet.Clear();
            dataAdapter.Fill(dataSet, "tblEx01");
            DataRow NewRow = dataSet.Tables["tblEx01"].NewRow();
            NewRow["name"] = textBox1.Text;
            NewRow["age"] = textBox2.Text;
            dataSet.Tables["tblEx01"].Rows.Add(NewRow);
            dataAdapter.Update(dataSet, "tblEx01");

            dataSet.Clear();
            dataAdapter.Fill(dataSet, "tblEx01");
            dataGridView1.DataSource = dataSet.Tables["tblEx01"];
        }
        // 수정
        private void button2_Click(object sender, EventArgs e)
        {
            int id = (int)dataGridView1.SelectedCells[0].Value;
            dataSet.Clear();
            dataAdapter.Fill(dataSet, "tblEx01");

            string strFilter = "id=" + id;
            DataRow[] FindRow = dataSet.Tables["tblEx01"].Select(strFilter);
            FindRow[0]["name"] = textBox1.Text;
            FindRow[0]["age"] = int.Parse(textBox2.Text);

            dataAdapter.Update(dataSet, "tblEX01");
            dataSet.Clear();
            dataAdapter.Fill(dataSet, "tblEx01");
            dataGridView1.DataSource = dataSet.Tables["tblEx01"];
        }
        // 삭제
        private void button3_Click(object sender, EventArgs e)
        {
            int id = (int)dataGridView1.CurrentRow.Cells["id"].Value;
            dataSet.Clear();
            dataAdapter.Fill(dataSet, "tblEx01");       
         
            string strFilter = "id=" + id;
            DataRow[] FindRow = dataSet.Tables["tblEx01"].Select(strFilter);
            FindRow[0].Delete();

            dataAdapter.Update(dataSet, "tblEX01");
            dataSet.Clear();
            dataAdapter.Fill(dataSet, "tblEx01");
            dataGridView1.DataSource = dataSet.Tables["tblEx01"];
        }
        // 새로고침
        private void button4_Click(object sender, EventArgs e)
        {
            dataSet.Clear();
            dataAdapter.Fill(dataSet, "tblEx01");
            dataGridView1.DataSource = dataSet.Tables["tblEx01"];
        }
    }

이 블로그의 인기 게시물

[C#] 연산자 목록(Operators)

[C#] C# 프로그램의 일반적인 구조(A skeleton of a C# program)

// A skeleton of a C# program  using System; namespace YourNamespace {     class YourClass     {     }     struct YourStruct     {     }     interface IYourInterface      {     }     delegate int YourDelegate();     enum YourEnum      {     }     namespace YourNestedNamespace     {         struct YourStruct          {         }     }     class YourMainClass     {         static void Main(string[] args)          {             //Your program starts here...         }     } } By Microsoft.MSDN :: .NET Guide Docs

[C#] .NET Configuration file :: App.config

프로그램의 옵션들을 담아 두는 파일로서 아주 예전에는 .INI 파일을 사용하였었으며, 이후 윈도우즈가 관리하는 레지스트리 데이타베이스에 시스템 및 응용프로그램의 옵션들을 저장하였다. 레지스트리는 프로그램의 옵션을 저장하는 훌륭한 저장 장소이나, 모든 응용프로그램이 항상 레지스트리에 데이타를 쓰는 권한을 갖는 것은 아니였기 때문에 Permission 제약점이 있었다. .NET Framework에서는 프로그램의 행위를 결정짓는 옵션들을 저장하기 위해 .Config 파일을 사용한다. 데스크탑 응용프로그램 .EXE 에 대해서 Configuration 파일(구성파일)은 .EXE.Config이 되는데, 예를 들어, TEST.EXE의 구성 파일은 TEST.EXE.Config가 된다. Visual Studio에서 콘솔, 윈폼, 혹은 WPF 등의  데스크탑 프로젝트를 생성한 후 App.config 파일을 추가하고(아래 그림처럼 Application Configuration File 추가) 여기에 필요한 옵션들을 설정한 후 빌드하면 .EXE 파일에 대한 .EXE.Config 파일이 자동으로 생성 된다. 그리고 이렇게 추가한 App.config 파일의 내용을 소스코드에서 사용하기위해서는 "참조"에서 '참조 추가하기'를 통해 반드시 에셈블리의 "System.Configurarion"을 추가하고 사용 할 소스코드에 using 문으로 추가해 주어야 한다.  " using System.Configuration; " <예제> [App.config] <?xml version="1.0" encoding="utf-8"?> <configuration>   <startup>     <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.6.1...