MySQL 관련 팁

2010년 09월 19일

1. MySQL 속도 관련
 > show status like '%cache%';
   캐싱 메모리 상태뵈
 - where 절에서 많이 사용되는 칼럼에는 인덱스를
 - varchar 타입보다 char 타입이 빠르긴하다
 - enum type 적절히 활용(cf set type)
 > SELECT col_name FROM tbl_name PROCEDURE ANALYSE();
   text, blob type은 TABLE 분리 추천
 - 버퍼 메모리를 시스템에 맞게 변경(/etc/my.cnf)
   sample) $MySQL_HOME/share/mysql/small, medium, large
 > SHOW TABLE STATUS [FROM db_name];
 > SHOW STATUS;
 > SHOW VARIABLES;
 > SHOW GRANTS FOR root@localhost;

2. MySQL root 비밀번호 분실시
 1) MySQL 데몬 킬
   #kill -9 MySQL_PID
 2) 권한 없이 데몬 재구동
   #mysqld_safe --skip-grant-tables
 3) 접속 및 비밀번호 변경
 4) 데몬 킬 및 데몬 재구동

3. Backup
  #mysqldump [OPTIONS] database [tables]
             [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3]
             [OPTIONS] --all-databases [OPTIONS]
   -a, --all
   -d, --no-data
   -n, --no-create-db
   -T, --tab=name

4. 권한 제약하여 사용자추가
 > GRANT SELECT,INSERT ON linux.sawon TO leejj@localhost
   IDENTIFIED BY '1234' WITH GRANT OPTION;
   linxu : db_name
   sawon : tbl_name
   leejj : MySQL account
   localhost : hostname
   1234 : password

5. UDF(User Define Function) 등록하기
 #vi getgrade.c
 #gcc -shared -o getgrade.so getgrade.c
 #cp getgrade.so /usr/lib/
 >CREATE FUNCTION getgrade RETURNS STRING SONAME "getgrade.so";



원본:

http://blog.naver.com/nogojiri22?Redirect=Log&logNo=120012959689
  

 
댓글은 로그인 사용자만 작성 가능합니다. 로그인하기