반응형


1.회원관련 명령어


(1) root 비밀번호 변경

mysql> use mysql;

Database changed

mysql> update user set authentication_string=password('10djraks^^') where user='root';

Query OK, 1 row affected, 1 warning (0.02 sec)

Rows matched: 1  Changed: 1  Warnings: 1


mysql> flush privileges;

Query OK, 0 rows affected (0.21 sec)


mysql> 



2.INDEX 관련 명령어


(1) 인덱스 생성

mysql)ALTER TABLE 테이블명 ADD INDEX `IDX_인덱스 이름` (`인덱스 컬럼명`) 


3.권한 관련 명령어


(1) 권한 생성


mysql> grant all privileges on DB명.* to 계정명@localhost identified by '비밀번호';

Query OK, 0 rows affected, 1 warning (0.23 sec)


mysql> grant all privileges on DB명.* to 계정명@'%' identified by '비밀번호';

Query OK, 0 rows affected, 1 warning (0.00 sec)


mysql> flush privileges;

Query OK, 0 rows affected (0.00 sec)

 



(2) 권한 삭제


mysql> revoke all on DB명..* from 계정명@'%'; 

Query OK, 0 rows affected, 1 warning (0.23 sec)


mysql> revoke all on DB명..* from 계정명@'localhost'; 

Query OK, 0 rows affected, 1 warning (0.23 sec)




반응형

'DB > Maria & Mysql' 카테고리의 다른 글

MS-SQL 주석달기  (0) 2013.08.28
MYSQL Data Repository(저장소) 변경방법  (0) 2012.12.31
[ MYSQL PROCESS LIST 보기 ]  (0) 2011.12.27
PK & UI 무엇이 올바른가?  (0) 2011.01.31
[ Mysql Concat 한글깨짐 ]  (0) 2011.01.13
반응형
Mysql에서 Process 관리를 하기 위해 종종 툴을 사용한다.

Mysql Administrator 란 Tool을 쓰기도 하는데, GUI 환경이어서 아주 편하게 되어있다.

오늘 이시간에는 콘솔에서 Process list를 보여주고 죽이고 하는 등등의 내용과 Tool 상에서

할 수 있는 것들에 대해 알아보겠다.

[1] 콘솔에서 접속 후 알아보기

콘솔이던 어디던 확실하게 전체 user의 상태를 체크해보기 위해서는 root 계정으로 들어가
확인해 보는것이 제일 확실하다.

로그인 하였다 가정하고 아래 메시지를 보도록 하자.

[1-1] Process List 를 조회하는 방법

 mysql> show full processlist;
+-------+--------+-----------------------+--------------+---------+------+-------+-----------------------+
| Id       | User   | Host                          | db               | Command | Time | State | Info                               |
+-------+--------+-----------------------+--------------+---------+------+-------+-----------------------+
| 48892 | testu    | localhost:33072           | gxxxxxxxe    | Sleep        | 5360 |           | NULL                           |
| 48899 | mxxxx | xxx.1xx.217.139:49333  | paxxxxxxxd  | Sleep        | 3582 |           | NULL                           |
| 48901 | mxxxx | xxx.1xx.217.139:49336  | paxxxxxxxd  | Sleep        | 3573 |           | NULL                           |
| 48903 | mxxxx | xxx.1xx.217.139:49343  | paxxxxxxxd  | Sleep        |     8 |            | NULL                           |
| 48961 | root     | localhost                    | NULL           | Query        |     0 |  NULL  | show full processlist     |
+-------+--------+-----------------------+--------------+---------+------+-------+-----------------------+

위 내용을 보면 show full processlist 란 명령어를 입력시 다음과 같이 현재 수행중인 Thread의 종류가 나오게 된다.

[1-2] Process List를 삭제하는 방법
mysql> kill 48899;

linux와 동일하게 kill이라는 명령어를 사용해서 상대방의 Thread를 강제 종료 가능하다.

[2] GUI를 통해서 확인하는 방법

Mysql Administrator를 이용하여 보면 위에 내용보다 조금 더 쉽게 조회 할 수 있다.
역시나 root계정으로 접속했을때 전체 유저에 대해 조회 가능하다.


위 내용에서 보듯이 각 유저별로 접속현황을 GUI환경에서 아주 쉽게 조회가능하다. 오른쪽 끝에 INFO 를 보면 알겠지만,
콘솔에서 show full processlist 명령어를 한것과 같은 효과이다.

지금까지 Mysql 상에서 Thread 조회 , 삭제 방법을 알아보았다. 다양한 view방법이 옵션별로 존재하지만, 크게 신경안써도
될듯하다. 추가적으로, 필요한 부분이 생기면 다시금 기록 하도록 하겠다.


                                                                                                         - 2012.12.27 랑이씀 -
반응형
반응형
현업에서 일을 하다보면 DB 모델링을 하는 경우가 많다.

어떤경우에는 PK / FK 관계를 이용해서 모델링 하는것이 바람직 하지만, 개발의 업무 효율상

PK/FK관계를 걸지 않고 UI(Unique Index)만 걸고 작업을 하는 경우가 많다.

이 둘 경우의 차이에 대해 공부하고 어떤상황에 적절히 쓰는것이 좋은지 글을 써 보도록

하겠다.

[1] PK & UI 차이점

우선적으로 PK 와 UI를 사용했을때 어떠한 차이점이 있는지 아래 표를 보도록하자.

                항목                  PK                   UI 
 목적  Constraint + Index   Index 
 공통점  유일성 보장  유일성 보장 
 참조 무결성  PK/FK에 의해 지정가능  지정 불가능 
 테이블당 개수  1개만 가능  여러 개 가능 
 인덱스 생성  Unique Index 생성  Unique Index 생성 
 NULL 허용  허용 안됨  허용됨  

위 표는 데이터 베이스 관련 블로그 북을 통해 타인의 지식을 가져온 것이다. 내 생각을
좀 넣으면 특정DB에 따라 UI의 경우 Null값이 Colume에 들어있을경우 해당 필드는 Index
검색을 타지 않는 것을 알게되었다.

[2] UI 를 사용했을때의 장점

UI만을 사용하여 DB모델링시 에는 어떠한 장단점이 있는지 한번 알아보자.
                         장점                              단점 
 - Relation이 걸리지 않아 DBA가 테이블 수정, 적용 등이 용이하여 관리하기가 수월하다.  - 데이터의 무결성이 깨질 수가 있다.
 - 무결성이 깨지는 경우를 대비하여 마이그레이션 및 각종 백업,복구작업시 데이터 정리 작업이 필수적이다.
 - 개발자 관점에서 Relation을 생각 하지 않아도 되기때문에 개발서 DB Lock , Transaction 관리등에 대해 다소 덜 신경써도 된다.  - Bean과 같은 데이터 모델과 테이블이 일치 하지 않아도 상관없는 방식 이기 때문에 개발모델구상시 모델관리가 불편함이 있다. 
 - PK/FK 를 사용하지 않기 때문에 특정 DB모델에서는 성능이 좋아지는 효과를 얻을 수 있다.  - UI는 한 테이블에 다수를 걸수 있으므로, PK가 무엇인지 육안으로 구분하기가 힘들다. 


[3] PK/FK 를 통한 모델링 방법
이번엔 PK/FK를 이용한 모델링에서의 장단점을 알아보도록 하자.
                           장점                           단점 
 - 무결성이 보장된다.( 무결성이 보장된 다는것은 데이터 관리면에서 매우 중요한 문제이다.)  없음 
 - 추후 Reverse Engine을 돌릴 시에 PK/FK의 관계는 역공학이 가능하다.  없음
 - FK를 사용해도 적절히 인덱스만 걸어준다면, 성능 저하 현상은 나타나지 않는다.  없음

[4] 어느것을 쓰는게 더 좋을까?
위에서 보듯이 PK/FK 방법의 단점은 거의 없다. 하지만, 어떤경우 UI만 가지고 모델링을 하느냐? ... 실제 필자가 과거 제로보드 XE버젼시기에 DB를 역공한 해본 경험이 있다.

모든 DB가 각각의 테이블이 존재하며 어떠한 관계도 엮어 있지 않은 것을 발견하였다. 그렇기 때문에 ER-D상으로 DB의 관계를 파악하는데 상당한 시간이 소모되었던 경험이 있다. 또한, 복잡한 테이블의 관계를 단순 느낌으로만 파악해야하는 것은 SM하는 입장에서 매우 좋지 않다. 마지막으로, 이미 개발되어진 부분을 수정시 참조 무결성을 타지 않아 , 무분별한 DML 작업이 가능했었다. Data란 퍼즐과 같다, 한부분이 깨지면 금방은 티가 나지 않지만, 시간이 지날수록 그 공백을 메우는 것은 불가능에 가깝다.

무결성이란 것은 왜 중요한가? 실제 db상에서 무결성을 지켜주지 않는다면, 개발자 입장에서는 Application에서 Transaction이나 또는, Syncronised 와 같은 동기화 를 이용하여 개발해야하는 번거로움이 있기 때문이다.

[5] 성능저하 문제
실제로 UI만 거는것이 성능에서는 월등하다는 편견을 가진 여러 책 또는 개발자들을 만나보았다. 내 생각은 이렇다. 과거 하드웨어적인 성능이 잘 따라주지 않았던 2000년도 이전 시기에는  pk/fk 가 성능을 떨어뜨린 적도 있었다. 하지만, 그것보다도 PK/FK 관계에서 FK에 대한 적절한 Index를 걸어주지 않아, Full Scan을 타버렸기 때문이다. 잘알고 적절히 쓴다면 크게 성능차이는 존재하지 않는다고 생각한다.

[6] 실제 UI를 이용한 사례
필자가 읽은 책에서 보았을때 전세계에서 유명한 ERP 프로그램인 SAP ERP / ORACLE ERP는 UI로만 모델링되어있다고 한다. 그 이유는 ERP 자체가 One Souce Multi Use 의 특징을 가지고 있기 때문이다. 각각의 ERP는 어떤 비지니스 환경이든 동일한 소스를 심어야 한다. 하지만 PK 가 절대적으로 고정되어 있으면, 일부 flexible을 요구하는 Site에서는 문제가 야기될 여지가 있기 때문에 내부적으로 차이가 있는 비지니스 모델을 수용하기 위해 UI를 종종쓴다.

위 내용에는 1가지 전제조건이 있다. 많은 테스트를 통해 Application에서 참조무결성을 지켜주어야 한다는것이다. 실제 위 프로그램의 경우 각 DB의 DBMS들이 소스코드를 통해 무결성을 유지하는 역할을 하는 로직을 포함하고 있기 때문에 PK/FK 가 걸려있는 것과 사실상 다를것이 없다.

[7] 마지막.
아 밤에 뭔짓인가 ... 엄청길게 썼네~~~ 괜시리 필받아서 ㅋㅋㅋㅋ
개발자 관점에서 DB를 얼마나 아느냐가 중요하다. 적절히 Query만 아는것도 크게 나쁘지는 않다. 하지만, DBA의 관점까지 접근가능하다며 더 좋은 소스코드를 만들수 있을것이다. PK/FK를 쓰느냐 UI를 쓰느냐,,, 대규모 프로젝트가 아닌이상 성능상의 퍼포먼스는 차이가 없다. 하지만, 자그마한것 하나하나 몸에 습관을 들여놔야만, 좋은개발자가 될 수 있다.

이상 

                                                               - 2011.01.31 랑이씀 -

출처 : 아는만큼 보이는 DB 참조.
         기타 타 웹사이트 참조
반응형

'DB > Maria & Mysql' 카테고리의 다른 글

MYSQL 자주쓰는 명령어  (0) 2012.09.10
[ MYSQL PROCESS LIST 보기 ]  (0) 2011.12.27
[ Mysql Concat 한글깨짐 ]  (0) 2011.01.13
[ WINDOWS OS 에서 MYSQL5.X ROOT 비밀번호 분실]  (0) 2011.01.04
MYSQL Tinyint(1) 의 의미  (2) 2010.07.27
반응형
Mysql Query 에서 한글이 깨지는 현상이 발생하였다.

Concat에서 문자열과 숫자를 Concat하니 한글깨짐현상이 나오는데 이걸 해결해야한다.

다음과 같은 쿼리를 보자.

[1] 테이블 정보
mysql> desc tb_menu_m;
+-----------------+------------------+------+-----+---------+----------------+
| Field           | Type             | Null | Key | Default | Extra          |
+-----------------+------------------+------+-----+---------+----------------+
| menu_seq        | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| menu_title      | varchar(50)      | NO   |     | NULL    |                |
| menu_url        | varchar(200)     | YES  |     | NULL    |                |
| menu_parent_seq | int(10) unsigned | NO   |     | NULL    |                |
| menu_level      | int(10) unsigned | NO   |     | NULL    |                |
| menu_position   | int(10) unsigned | NO   |     | NULL    |                |
| menu_left       | int(10) unsigned | YES  |     | NULL    |                |
| menu_right      | int(10) unsigned | YES  |     | NULL    |                |
| menu_type       | varchar(10)      | YES  |     | NULL    |                |
| comment         | varchar(200)     | NO   |     | NULL    |                |
| register_time   | datetime         | NO   |     | NULL    |                |
| modfiy_time     | datetime         | YES  |     | NULL    |                |
+-----------------+------------------+------+-----+---------+----------------+
12 rows in set (0.00 sec)


[2] 한글깨짐 쿼리
mysql> select concat(menu_title,menu_seq) from tb_menu_m limit 1;
+-----------------------------+
| concat(menu_title,menu_seq) |
+-----------------------------+
| ?쒖뒪?쒓?由?            |
+-----------------------------+
1 row in set (0.00 sec)

[3] 해결방안
위내역은 menu_seq가 int형이기 때문이다. 저놈을 char로 캐스팅을 하면 괜찮아진다.
mysql> select concat(menu_title,cast(menu_seq as char)) from tb_menu_m limit 1;
+-------------------------------------------+
| concat(menu_title,cast(menu_seq as char)) |
+-------------------------------------------+
| 시스템관리1                               |
+-------------------------------------------+
1 row in set (0.00 sec)

간단하지만 concat는 컬럼이 다른경우 저런현상을 나타냄을 경험을 통해 알수 있었다.

이상 랑이의 ㅋㅋ 경험담. 끝
 
                                                                           - 2011-01-13 랑이씀 -


반응형

+ Recent posts