Database
2017.12.01 01:50
[mysql] MySQL 한글 깨짐 현상 해결하기(UTF8)
조회 수 5480 댓글 0
MySQL DB에 값을 입력하거나 백업(dump) 파일을 복원할 때 한글 값이 제대로 저장되지 않는 경우가 있다. 이런 경우 대부분 character set 설정문제이며 UTF-8로 설정하면 쉽게 고칠 수 있다.
MySQL 설치 기본 상황
- latin1으로 Character-Set이 설정되어있다.
- 한글을 사용하기 위해서는 UTF-8로 변경하면 사용할 수 있다.
MySQL 한글 깨짐 현상 해결하기
- 한글을 저장하면 아래와 같은 ??? 형태의 모습을 볼 수 있다.
+---+-----+
|id |name |
+---+-----+
|1 |??? |
|2 |??? |
+---+-----+
설정파일 변경하기
- /etc/mysql/my.cnf 파일 변경하기
- 파일의 경로는 플랫폼에 따라 다를 수 있다.
# 추가 해줘야 할 내용
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
collation-server = utf8_unicode_ci
init-connect='SET NAMES utf8'
character-set-server = utf8
기존의 만들어져있던 Database나 Table들의 Character-Set이 변경되는 것은 아니므로 직접 변경을 해줘야 한다.
# 기존의 Database의 Character-Set 속성 변경하기
mysql> ALTER DATABASE [DB명] DEFAULT CHARACTER SET utf8;
# 현재 Character-Set 확인하기
mysql> show variables like ‘c%’
mysql> status
# MySQL 재시작하기
[root@hooni ~]# service mysql restart
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
909 | System/OS | [router] 시스코 라우터 명령어 모드.. | hooni | 2013.04.23 | 12948 |
908 | Algorithm | [security] 블럭 암호에 대해서.. | hooni | 2013.04.23 | 17124 |
907 | System/OS | [router] 라우팅 프로토콜 BGP (간단한 세팅) | hooni | 2013.04.23 | 10953 |
906 | System/OS | 네트워크별 MTU(최대 전송 단위) | hooni | 2013.04.23 | 17645 |
905 | System/OS | OSI (Open Systems Interconnection) 개방형 시스템간 상호 접속 | hooni | 2013.04.23 | 10789 |
904 | System/OS | 라우팅 경로 결정 영향 요소 ㅋㅋ | hooni | 2013.04.23 | 15855 |
903 | System/OS | [owasp] 10대 웹어플리케이션 보안 취약 | hooni | 2013.04.23 | 15910 |
902 | Database | [mysql] 루트 암호 초기화 | hooni | 2013.04.23 | 11048 |
901 | Algorithm | Polynomial time 이란? ㅋㅋ | hooni | 2013.04.23 | 22696 |
900 | System/OS | [linux] /etc/fstab 설정 방법.. ㅋㅋ | hooni | 2013.04.23 | 12086 |
899 | Algorithm | 암호 알고리즘 및 프로토콜의 이해.. | hooni | 2013.04.23 | 17215 |
898 | Develop | [js] One Time Pad key generatorㅡ.,ㅡ; | hooni | 2013.04.23 | 6794 |