Database
2017.12.01 01:50
[mysql] MySQL 한글 깨짐 현상 해결하기(UTF8)
조회 수 6054 댓글 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
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
1103 | Develop | [php][laravel] 초간단 MacOS에서 Laravel 개발 환경 구축 | hooni | 2017.12.15 | 2483 |
1102 | Database | [mysql] MacOS에 MySQL 설치, 설정, 암호 재설정 | hooni | 2017.12.15 | 2046 |
1101 | Database | [mysql] ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement. | hooni | 2017.12.15 | 2034 |
1100 | Develop | [js] 문자열에서 숫자만 걸러내기 (jQuery 안쓰고 정규표현식) | hooni | 2017.12.14 | 1684 |
1099 | Develop | [js] URL 파싱하기 (jQuery 안쓰고) | hooni | 2017.12.14 | 1768 |
1098 | System/OS | [linux] 초간단 SquirrelMail 설치/설정 (다람쥐 메일) | hooni | 2017.12.11 | 5037 |
1097 | System/OS | [linux] 초간단 Postfix, Covecot, SSL/TLS (SMTP) | hooni | 2017.12.11 | 10076 |
1096 | Develop | [php] Laravel 5.4: Specified key was too long error | hooni | 2017.12.04 | 10651 |
1095 | Develop | [php] mysql_ 과 mysqli_ 의 차이 | hooni | 2017.12.01 | 2209 |
» | Database | [mysql] MySQL 한글 깨짐 현상 해결하기(UTF8) | hooni | 2017.12.01 | 6054 |
1093 | Etc | RSVP 란? | hooni | 2017.11.22 | 1621 |
1092 | Database | [mysql] 중복데이터 삭제하는 초간단 쿼리 | hooni | 2017.11.22 | 3907 |