>데이터 베이스 >MySQL 튜토리얼 >mysql 세트 문자 세트

mysql 세트 문자 세트

王林
王林원래의
2023-05-08 09:36:063297검색

MySQL은 강력한 오픈 소스 데이터베이스로서 다양한 산업 분야의 대부분의 애플리케이션에서 널리 사용됩니다. MySQL을 사용할 때 문자셋 설정은 매우 중요한 문제입니다. 이 기사에서는 개발자가 MySQL 데이터베이스를 올바르게 사용할 수 있도록 MySQL 문자 집합을 설정하는 방법을 소개합니다.

1. 문자 집합의 개념

문자 집합은 코드와 문자 간의 매핑 관계에 대한 사양입니다. 컴퓨터 문자의 인코딩 방법을 지정합니다. 문자 집합은 데이터베이스 시스템마다 설정이 다를 수 있으며, 문자 집합마다 특성과 장점이 다릅니다. 예를 들어, 중국어 문자를 처리할 때 GB2312/GBK/GB18030은 Latin1/Latin7보다 장점이 있습니다.

MySQL에서 문자 세트는 데이터베이스, 테이블 및 열의 문자 데이터 인코딩을 나타냅니다. 일반인의 용어로 문자 집합은 문자와 문자열을 저장하고 처리하는 데 사용되는 방식을 나타냅니다.

MySQL에서 지원되는 문자 집합에는 주로 ASCII, GBK, GB2312, UTF-8, UTF-16 및 ISO-8859 등이 포함됩니다. 그중 UTF-8은 MySQL에서 가장 일반적으로 사용되는 문자 집합입니다. 다양한 언어, 유연한 인코딩 형식, 공간 절약 및 기타 이점을 지원합니다.

2. MySQL 캐릭터셋 설정 방법

  1. MySQL에서 지원하는 캐릭터셋 조회

MySQL 데이터베이스에서는 명령어를 통해 해당 데이터베이스에서 지원하는 캐릭터셋을 조회할 수 있으며, 방법은 다음과 같다.

SHOW CHARACTER SET;

이 명령은 다음과 같이 MySQL에 사용할 수 있는 다양한 문자 집합을 나열할 수 있습니다.

Big5 전통 중국어big5_chinese_ci dec8_swedish_ci11111111 3 21 121 1 211321111114144114 1123
2 dec8 DEC 서유럽
cp850 DOS 서유럽 cp8 50_general_ci
hp8 HP 서유럽 hp8_english_ci
koi8r KOI8-R Relcom Russian koi8r_general_ci
latin1 iso-8859-1 서유럽어 latin1_swedish_ci
latin2 iso-8859-2 중앙 유럽 latin2_general_ci
swe7 7bit Swedish swedish_ci
ascii US ASCII ascii_general_ci
ujis EUC-JP 일본어 ujis_japanese_ci
sjis Shift-JIS 일본어 sjis_japanese_ci
hebrew iso-8 859-8 히브리어 hebrew_general_ci
tis620 TIS620 태국어 tis620_thai_ci
euckr EUC-KR 한국어 euckr_korean_ci
koi8u KOI8-U 우크라이나어 koi8u_general_ci
gb2312 GB2312 중국어 간체 gb2312_chinese_ci
gbk GBK 중국어 간체 gbk_chinese_ci
latin5 iso-8859-9 터키어 latin5_turkish_ci
armcii8 ARMSCII-8 아르메니아어 armscii8_general_ci
utf8 UTF-8 Unicode utf8_general_ci
ucs2 UCS-2 유니코드 ucs2_general_ci
cp866 DOS 러시아어 cp8 66_general_ci
keybcs2 DOS Kamenicky 체코어-슬로바키아어 keybcs2_general_ci
macce Mac 중앙 유럽 macce_general_ci
macroman Mac 서부 유럽 macroman_general_ci
cp852 DOS 중앙 유럽 cp852_general_ci
latin7 iso-8859-13 발트해 latin7_general_ci
utf8mb4 UTF-8 유니코드 utf8mb4_gener al_ci
cp1251 Windows 키릴 문자 cp1251_general_ci
utf16 UTF-16 유니코드 utf16_general_ci
utf16le UTF-16LE 유니코드 utf16le_general_ci
cp1256 Windows 아랍어 cp1256_general_ci
cp1257 Windows 발트어 cp1257_general_ci
utf32 UTF-32 유니코드 utf32_general_ci
binary 이진 의사 문자 집합 binary
geostd8 GEOSTD8 조지아어 geostd8_general_ci
cp932 Windows용 SJIS 일본어 cp932_japanese_ci
eucjpms Windows용 UJIS 일본어 eucjpms_japanese_ci
  1. 데이터베이스의 문자 집합 설정

새 MySQL 데이터베이스를 생성할 때 데이터베이스의 모든 테이블의 문자 집합이 이 문자 집합을 사용하도록 데이터베이스의 기본 문자 집합을 설정할 수 있습니다. 구체적인 단계는 다음과 같습니다.

2.1 먼저 MySQL에서 지원하는 문자 집합을 확인하세요.

mysql> SHOW CHARACTER SET;

2.2 새 데이터베이스를 생성할 때 문자 집합 설정을 추가하세요.

CREATE DATABASE new_db CHARACTER SET utf8;

또는

CREATE DATABASE new_db DEFAULT CHARACTER SET utf8;

여기서 utf8은 일반적으로 사용되는 문자 집합 중 하나입니다.

  1. MySQL 테이블의 문자 집합 설정

테이블의 필드가 데이터를 올바르게 저장하고 표시하려면 테이블의 문자 집합을 설정해야 합니다. MySQL에서는 테이블을 생성할 때 테이블의 문자 집합을 설정할 수 있습니다. 테이블이 생성된 경우 Alter 명령을 통해 테이블을 수정할 수도 있습니다.

3.1 테이블 생성 시 문자셋 설정

CREATE TABLE new_table (
id INT(11) NOT NULL AUTO_INCREMENT,
name VARCHAR(50) NOT NULL DEFAULT '',
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

그 중 ENGINE=InnoDB는 테이블의 스토리지 엔진을 설정하는 데 사용되고, CHARSET=utf8은 테이블의 기본 문자 집합을 설정하는 데 사용됩니다.

3.2 테이블의 문자 집합 수정

ALTER TABLE old_table CONVERT TO CHARACTER SET utf8;

or

ALTER TABLE old_table MODIFY COLUMN name VARCHAR(50) CHARACTER SET utf8;

그 중 CONVERT TO 명령은 다음과 같습니다. 테이블을 수정하는 데 사용됩니다. 기본 문자 집합인 MODIFY COLUMN 명령은 테이블에 있는 열의 문자 집합을 수정하는 데 사용됩니다.

  1. MySQL 연결을 위한 문자 집합 설정

MySQL 서버에 연결할 때 작업에 대한 문자 집합을 설정할 수도 있습니다. 이 문자 집합 설정은 종종 "클라이언트 문자 집합"이라고도 하며 클라이언트에서 전송되는 데이터의 문자 집합을 나타냅니다.

4.1 현재 연결의 문자 집합 보기

mysql> SELECT @@character_set_connection;

4.2 연결의 문자 집합 수정

SET Character_set_connection = utf8;

or

mysql --default-character-set =utf8 -u root -p

이 중 SET 명령은 연결의 기본 문자 집합을 수정할 수 있으며, --default-character-set 명령은 클라이언트 문자 집합을 지정할 수 있습니다.

  1. 기타 문자 집합 설정

경우에 따라 드문 데이터 저장 및 변환 시나리오를 처리하기 위해 MySQL의 다른 문자 집합 설정을 켜야 할 수도 있습니다. 이때 MySQL 구성 파일인 my.cnf 파일을 수정해야 할 수 있습니다. 이 파일을 수정하려면 관리자 권한이 필요할 수 있습니다. 수정 방법은 다음과 같습니다.

5.1 my.cnf 파일 찾기

Linux에서 my.cnf 파일은 일반적으로 /etc/my.cnf 또는 /etc/mysql/my.cnf 디렉터리에 저장됩니다.

Windows에서 my.cnf 파일은 일반적으로 MySQL 데이터베이스의 설치 디렉터리에 저장됩니다.

5.2 my.cnf 파일 수정

my.cnf 파일에 다음 명령문을 추가합니다.

[mysqld]
character_set_server=utf8
init_connect='SET NAMES utf8'

그 중 Character_set_server 명령을 사용하여 나열된 문자 설정 설정, init_connect 명령은 연결을 생성할 때 문자 세트를 자동으로 설정하는 데 사용됩니다.

  1. 요약

MySQL은 매우 인기 있는 오픈 소스 데이터베이스이며 문자 집합 설정이 매우 중요한 역할을 합니다. MySQL의 문자 집합을 올바르게 설정하면 데이터를 정상적으로 읽고, 쓰고, 저장할 수 있습니다. 이 기사에서는 MySQL 문자 세트의 기본 개념, 데이터베이스, 테이블 및 연결을 생성할 때 문자 세트를 설정하는 방법, 더 많은 문자 세트 설정을 활성화하기 위해 my.cnf 파일을 수정하는 방법을 소개합니다. 이러한 지식은 개발자에게 더 나은 도움이 될 수 있습니다. MySQL을 사용하세요.

위 내용은 mysql 세트 문자 세트의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.