[mysql] MySQL 한글 깨짐 현상 해결하기(UTF8)
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
-
[mysql] 루트 암호 초기화
-
[mysql] MySQL 한글 깨짐 현상 해결하기(UTF8)
-
[mysql] MySql 에서 정렬 후 그룹 하는 방법
-
[mysql] MySQL 백업 및 복구
-
[mysql] MySQL 데이터베이스 추가 및 사용자 추가
-
[mysql] mysql user 생성시 ERROR 1364
-
[mysql] MySQL server has gone away 에러 대응
-
[mysql] MySql DB/테이블 사이즈 확인을 위한 쿼리
-
[mysql] MacOS에 MySQL 설치, 설정, 암호 재설정
-
[mysql] error while loading shared libraries: libmysqlclient.so.10:
-
[mysql] ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
-
[mysql] DB->Text, Text->DB 변환