'MySQL'에 해당되는 글 2건

  1. 2008.11.06 c# mysql 연결
  2. 2008.11.04 mysql 패스워드
SQL
posted by 준치 2008. 11. 6. 02:25

C#은 mysql커넥터 없이는 mysql을 사용할 수 없습니다
주로 mssql과 연동하여 사용하는데 필자는 꼭 반드시 미친듯이 mysql을 사용해야 했으므로
그 사용예제를 올려봅니다 ^^

먼저 첨부된 파일을 C# 라이브러리에 추가하고..
상단에

MySql.Data.MySqlClient가 using 되어 있어야 합니다.

그리고 첫번째 예제

public void MyMathod(){

      MySqlConnection connection;
      connection = new MySqlConnection();

      string connectionString =             "server=127.0.0.1;database=MY_DB;uid=MY_ID;pwd=MY_PW;";

            connection.ConnectionString = connectionString;

            try
            {

                string commandStirng = "select * from test";

                MySqlDataAdapter DBAdapter = new MySqlDataAdapter(commandStirng, connection);
                DataSet DS = new DataSet();
                DBAdapter.Fill(DS, "test");

                dataGridView1.DataSource = DS.Tables["test"].DefaultView;
                //MessageBox.Show("연결됨");

            }
            catch (Exception E)
            {
                MessageBox.Show(E.ToString());
            }
            finally
            {
                connection.Close();
            }
}

기본 골격이고 신경써야 할 부분은 형광색 부분입니다.
1. 127.0.0.1 : Mysql이 설치된 원격지의 데이터베이스 IP어드레스 입니다.
2. MY_DB : 사용할 데이터베이스명
3. MY_ID : 데이터베이스 사용 ID
4. MY_PW : 데이터베이스 사용 PASSWORD
5. select * from test : 데이터베이스에 질의할 쿼리(본 예제는 Select로만 응용가능합니다)
예) select * from test where field1 = 1;
     select * from test order by field2 desc;
6. test : DBAdapter와 DS.Tables에 쿼리에 질의한 테이블 명을 적어 줍니다.
예) select * from angpang; //테이블 명이 angpang 입니다.
    .............................
    string commandStirng = "select * from angpang";

                MySqlDataAdapter DBAdapter = new MySqlDataAdapter(commandStirng,         connection);
                DataSet DS = new DataSet();
                DBAdapter.Fill(DS, "angpang");

                dataGridView1.DataSource = DS.Tables["angpang"].DefaultView;
                //MessageBox.Show("연결됨");
    .............................

7. dataGridView1 : 주로 결과값은 데이터그리드 뷰 컨트롤과 많이 사용합니다. 데이터그리드 뷰를 추가하여 Name 속성을 맞춰주면 결과값이 보여질 것입니다.

시간나면 Update 쿼리 응용법, Insert 쿼리 응용법, 데이터그리드뷰를 효율적으로 쓰는방법,
데이터베이스에 이미지를 2진코드로 저장하여 활용하는법 등을 기술해 보겠습니다.
감사합니다 ^^

SQL
posted by 준치 2008. 11. 4. 10:59
1. 초기 mysql root 패스워드 설정하기
mysql 서버에 패스워드 없이 로그인 하게되면 서버에 만들어진 데이터베이스나 테이블
기타 이곳에 저장된 자료가 외부인에게 노출될 수 있다. 따라서 이러한 보안을 목적으로
root 패스워드를 지정하면 mysql 서버를 안전하게 보호할 수 있다.

mysql> use  mysql;
mysql> update  user  set  password=password('123456') where user='root';
Query OK, 2 rows affected (0.03 sec)
Rows matched: 2  Changed: 2  Warnings: 0
mysql> flush  privileges; <--- 적용
flush privileges; 를 하지 않으면 mysql에서 빠져나와서 root 로그인이 안된다.
확인한다.
mysql> select  host, user, password  from  user;
+----------------------------------------------------------------+
| Host                          user              password       |
+----------------------------------------------------------------+
| localhost                     root          2e01146f5c065853   |
| localhost.localdomain         root          2e01146f5c065853   |
+----------------------------------------------------------------+

mysql> \q
Bye
------------------------------------------------------------------------------------
[주의]# mysql -u root -p
Enter password:
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
그대는 mysql 을 shutdown 하거나 reload 하면 된다.
# /usr/local/mysql/bin/mysqladmin -u root -p shutdown
하면 패스워드를 묻는데 이때 입력하면 설정한 mysql이 적용이된다.
# /usr/local/mysql/bin/mysqladmin -u root -p reload;
------------------------------------------------------------------------------------

# mysql -u root -p [Enter]       //  root 패스워드로 로그인
Enter password: ******

※ Mysql 서버에 root 패스워드가 설정되면 이제 부터는 mysql 서버에 접속하기 위해서는
위와 같이 -u 뒤에 root입력하고 -p 옵션을 사용하여 패스워드를 사용한다는 것을 명시해야 한다.
그리고 엔터를 치면 root 패스워드를 입력받기 위해 커서가 멈춘다.
(mysql 명령어만 입력하고 엔터를 치면 패스워드를 묻지 앟고 바로 mysql> 프롬프트가 나온 옛 시절을 생각해 보면 금방 차이를 느낄수 있음) 

2. 루트 비번 변경
mysql> use  mysql;
mysql> update  user  set  password=password('123456') where user='root';
mysql> flush  privileges;

3. root 패스워드를 분실한 경우(응급조치)

mysql을 오랫동안 사용하지 않았을 경우에 간혹 root패스워드가 기억나질않아서 당황할 때가 있습니다.  시스템관리자라면 시스템의 root나 MySQL의 root의 암호를 잊어 버렸을 때를 대비해서 패스워드를 새로 설정하는 방법을 반드시 숙지하고 있어야 할 것입니다.

① 실행중인 msyql 종료

# ps -ef | grep mysqld
root      9567     1  0 Mar16 ?        00:00:00 sh ./mysqld_safe
root      9576  9567  0 Mar16 ?        00:00:00 /usr/local/mysql/libexec/mysqld
root      9578  9576  0 Mar16 ?        00:00:00 /usr/local/mysql/libexec/mysqld
root      9579  9578  0 Mar16 ?        00:00:00 /usr/local/mysql/libexec/mysqld

# killall mysqld

② grant-table 미사용모드로 mysql시작(권한 테이블을 사용하지 않는 옵션으로 데몬 실행)

# ./safe_mysqld  --skip-grant-tables &
[1] 12084
# Starting mysqld daemon with databases from /usr/local/mysql/data
#

# ./mysql -u  root  mysql
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1 to server version: 3.22.24
Type 'help' for help.
mysql>

※ mysqld_safe 명령어는 mysql 데몬을 실행시킨다.

③ update문으로 root사용자 패스워드 갱신

mysql> update user set password=password('123') where user = 'root';
Query OK, 3 rows affected (0.00 sec)
Rows matched: 3  Changed: 3  Warnings: 0
mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec)
mysql> \q         
Bye

④ 실행중인 mysql 다시 종료(권한 테이블을 사용하지 않는 데몬을 종료)

# ps -ef | grep mysqld
root     12084 11558  0 20:10 pts/2    00:00:00 sh ./mysqld_safe --skip-grant-ta
root     12090 12084  0 20:10 pts/2    00:00:00 /usr/local/mysql/libexec/mysqld
root     12092 12090  0 20:10 pts/2    00:00:00 /usr/local/mysql/libexec/mysqld
root     12093 12092  0 20:10 pts/2    00:00:00 /usr/local/mysql/libexec/mysqld
#
# killall mysqld
mysqld daemon ended
[1]+  Done                    ./mysqld_safe --skip-grant-tables
#

⑤  Mysql 데몬 재 실행 후 갱신된 패스워드로 로그인

# ./safe_mysqld &
[1] 12102
# Starting mysqld daemon with databases from /usr/local/mysql/data
#

# ps -ef | grep mysql
root     12102 11558  0 20:13 pts/2    00:00:00 sh ./mysqld_safe
root     12108 12102  0 20:13 pts/2    00:00:00 /usr/local/mysql/libexec/mysqld
root     12110 12108  0 20:13 pts/2    00:00:00 /usr/local/mysql/libexec/mysqld
root     12111 12110  0 20:13 pts/2    00:00:00 /usr/local/mysql/libexec/mysqld

# mysql -u  root  -p
Enter Password: ***************