성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] VT sequences to "CONOUT$" vs. STD_O...
[정성태] NetCoreDbg is a managed code debugg...
[정성태] Evaluating tail call elimination in...
[정성태] What’s new in System.Text.Json in ....
[정성태] What's new in .NET 9: Cryptography ...
[정성태] 아... 제시해 주신 "https://akrzemi1.wordp...
[정성태] 다시 질문을 정리할 필요가 있을 것 같습니다. 제가 본문에...
[이승준] 완전히 잘못 짚었습니다. 댓글 지우고 싶네요. 검색을 해보...
[정성태] 우선 답글 감사합니다. ^^ 그런데, 사실 저 예제는 (g...
[이승준] 수정이 안되어서... byteArray는 BYTE* 타입입니다...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>C# - 닷넷 응용 프로그램에서 MySQL(MySqlConnector) 사용</h1> <p> 예전에 PHP를 통해 MySQL을 사용하는 방법을 소개했었는데요.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > .NET 개발자가 처음 해보는 PHP + MySQL 연동 ; <a target='tab' href='http://www.sysnet.pe.kr/2/0/1058'>http://www.sysnet.pe.kr/2/0/1058</a> </pre> <br /> MySQL의 환경 설정은 중복 설명하지 않고 ^^ 위의 것을 그대로 따를 것입니다. (하지만, 이 글에서 테스트한 MySQL 버전은 5.5입니다. 별 차이는 없겠지만. ^^)<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > DB(Schema): mytestdb 테이블: mytable 칼럼: id int NOT NULL name varchar(50) age int description varchar(150) </pre> <br /> C#에서 MySQL을 사용하려면 ODBC나 전용 ADO.NET Data Provider를 사용해야 할텐데요. 다행히 MySQL 측에서 Connector/Net이라는 "ADO.NET driver for MySQL"을 제공해 주고 있으니 이를 사용하면 됩니다. (소스 코드도 공개되어 있습니다.)<br /> <br /> <strike>다운로드는 다음의 경로에서 받고,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Download Connector/Net ; <a target='tab' href='http://dev.mysql.com/downloads/connector/net/'>http://dev.mysql.com/downloads/connector/net/</a> </pre> <br /> 오늘 날짜(2012-01-16) 기준으로 6.6.4 버전이 최신입니다. 제 경우에는 MSI 파일로 설치했습니다.<br /> <br /> 정상적으로 설치되고 나면, C:\Program Files (x86)\MySQL\MySQL Connector Net 6.6.4\Assemblies 경로에 v2.0, v4.0의 하위 폴더가 생기고 그 안에 각각 다음의 어셈블리들이 포함되어 있습니다. (물론, GAC에도 등록됩니다.)<br /> <br /> <ul> <li>MySql.Data.CF.dll</li> <li>MySql.Data.dll</li> <li>MySql.Data.Entity.dll</li> <li>MySql.Web.dll</li> </ul> <br /> 이 중에서 일반적인 ASP.NET에서 사용하는 용도로는 MySql.Data.dll만 있으면 됩니다. 그 파일만 복사해서 다른 컴퓨터의 Visual Studio에서 참조 추가한 후 다음과 같이 코딩을 해도 MySQL 사용이 가능합니다. (즉, 굳이 MSI 파일을 설치할 필요는 없습니다.)<br /> </strike> <br /> nuget을 통해 설치할 수 있습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > // <a href='https://www.nuget.org/packages/MySqlConnector/'>https://www.nuget.org/packages/MySqlConnector/</a> Install-Package MySqlConnector </pre> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > using System; using System.Data; <span style='color: blue; font-weight: bold'>using MySql.Data.MySqlClient;</span> namespace ConsoleApplication1 { class Program { private void CreateMySqlTable(MySqlConnection connection) { string query = "CREATE TABLE IF NOT EXISTS mytable("; query += " id INT NOT NULL, "; query += " NAME VARCHAR(50) NOT NULL PRIMARY KEY, "; query += " age INT NOT NULL, "; query += " DESCRIPTION VARCHAR(150) NOT NULL)"; MySqlCommand createCommand = new MySqlCommand(); createCommand.Connection = connection; createCommand.CommandText = query; createCommand.ExecuteNonQuery(); } static void Main(string[] args) { using (MySqlConnection myConnection = new MySqlConnection(@"Data Source=192.168.0.11;Database=mytestdb;User Id=mytest;Password=mytest@2008")) { myConnection.Open(); CreateMySqlTable(myConnection); // Create MySqlCommand insertCommand = new MySqlCommand(); insertCommand.Connection = myConnection; insertCommand.CommandText = "INSERT INTO mytable(id, NAME, age, DESCRIPTION) VALUES (@id, @NAME, @age, @DESCRIPTION)"; insertCommand.Parameters.Add("@id", MySqlDbType.Int32, 50); insertCommand.Parameters.Add("@NAME", MySqlDbType.VarChar, 50); insertCommand.Parameters.Add("@age", MySqlDbType.Int32, 50); insertCommand.Parameters.Add("@DESCRIPTION", MySqlDbType.VarChar, 150); string nameValue = "Name" + Guid.NewGuid().ToString(); insertCommand.Parameters[0].Value = 0; insertCommand.Parameters[1].Value = nameValue; insertCommand.Parameters[2].Value = 10; insertCommand.Parameters[3].Value = nameValue + "_Description"; int affected = insertCommand.ExecuteNonQuery(); Console.WriteLine("# of affected row: " + affected); // Update MySqlCommand updateCommand = new MySqlCommand(); updateCommand.Connection = myConnection; updateCommand.CommandText = "UPDATE mytable SET DESCRIPTION=@DESCRIPTION WHERE NAME=@NAME"; updateCommand.Parameters.Add("@NAME", MySqlDbType.VarChar, 50); updateCommand.Parameters.Add("@DESCRIPTION", MySqlDbType.VarChar, 150); updateCommand.Parameters[0].Value = nameValue; updateCommand.Parameters[1].Value = nameValue + "_Description2"; affected = updateCommand.ExecuteNonQuery(); Console.WriteLine("# of affected row: " + affected); // Select - ExecuteScalar MySqlCommand selectCommand = new MySqlCommand(); selectCommand.Connection = myConnection; selectCommand.CommandText = "SELECT count(*) FROM mytable"; object result = selectCommand.ExecuteScalar(); Console.WriteLine("# of records: " + result); // Select - DataTable DataSet ds = new DataSet(); MySqlDataAdapter da = new MySqlDataAdapter("SELECT * FROM mytable", myConnection); da.Fill(ds, "mytable"); DataTable dt = ds.Tables["mytable"]; foreach (DataRow dr in dt.Rows) { Console.WriteLine(string.Format("Name = {0}, Desc = {1}", dr["NAME"], dr["DESCRIPTION"])); } // Delete MySqlCommand deleteCommand = new MySqlCommand(); deleteCommand.Connection = myConnection; deleteCommand.CommandText = "DELETE FROM mytable WHERE NAME=@NAME"; deleteCommand.Parameters.Add("@NAME", MySqlDbType.VarChar, 50); deleteCommand.Parameters[0].Value = nameValue; affected = deleteCommand.ExecuteNonQuery(); Console.WriteLine("# of affected row: " + affected); } } } } </pre> <br /> 사용이 정말 쉬워졌군요. ^^ 영국의 어떤 개발자 한 분이 애플리케이션 서버는 C#/닷넷/윈도우가 담당하고 그 외 기반은 오픈 소스 기반으로 한다는데... 제법 현실성이 있습니다. C#/닷넷의 생산성과 인프라의 저비용화가 적절히 맞아떨어지는 것 같습니다.<br /> <br /> <hr style='width: 50%' /><br /> <br /> 참고로, mysql.exe 실행시 Access denied 오류가 발생하는 경우가 있었습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > C:\Program Files\MySQL\MySQL Server 5.5\bin><span style='color: blue; font-weight: bold'>mysql</span> ERROR 1045 (28000): Access denied for user 'ODBC'@'localhost' (using password: NO) C:\Program Files\MySQL\MySQL Server 5.5\bin><span style='color: blue; font-weight: bold'>mysql -u root</span> ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO) </pre> <br /> 이럴 때는 그냥 -p 옵션을 부과해서 암호까지 입력하겠다고 명시해야 합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > C:\Program Files\MySQL\MySQL Server 5.5\bin>mysql -u root -p Enter password: </pre> <br /> <a target='tab' href='http://www.sysnet.pe.kr/bbs/DownloadAttachment.aspx?fid=758&boardid=331301885'>첨부된 파일은 MySql.Data.dll이 포함된 간단한 소스 코드 예제</a>입니다.<br /> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
1182
(왼쪽의 숫자를 입력해야 합니다.)