MySQL에서 테이블 명을 한글로 만들고 싶습니다.
글쓴이: jin6093 / 작성시간: 금, 2008/10/24 - 2:11오후
처음 MySQL을 설치하니 기본 문자셋이 Latin1이었습니다. 테이블 이름을 한글로 만들려고 하니 안되더군요.
MySQL에서 문자셋을 UTF-8로 변경하는 방법을 찾아서 정리해 보니 아래와 같습니다. UTF-8에서도 한글로 된 테이블 이름이 만들어지지 않습니다. 문자셋을 어떻게 변경하면 테이블 명을 한글로 만들 수 있을까요?(= MySQL에서 한글을 사용할 수 있을까요?)
/etc/my.cnf 파일을 열어서 아래와 같이 문자셋을 변경합니다. [client] default-character-set=utf8 [mysqld] init_connect=SET collation_connection=utf8_general_ci init_connect=SET NAMES utf8 default-character-set=utf8 character-set-server=utf8 collation-server=utf8_general_ci [mysql] default-character-set=utf8 [mysqldump] default-character-set=utf8 mysql 재시작(# /etc/init.d/mysqld restart) 후, mysql에 접속해서 show variables like 'c%'; 로 문자셋이 변경되었는지 확인 합니다. 아래와 같이 나온다면 성공입니다. character_set_client : utf8 character_set_connection : utf8 character_set_database : utf8 character_set_results : utf8 character_set_server : utf8 character_set_system : utf8 character_sets_dir : /usr/share/mysql/charsets/ collation_connection : utf8_general_ci collation_database : utf8_general_ci collation_server : utf8_general_ci
------------------------------------------
Forums:
반드시 인용 식별자를 해 줘야 합니다.
테이블 명에 특수 문자가 있거나, MySQL 예약어를 테이블 명으로 쓴다거나 할 때는 반드시 인용 식별자를 해 줘야 합니다.
인용 식별자는 backtick ('`')을 사용하면 됩니다.
이를테면 create table `테스트` (.....) 라고 하면 됩니다.
--
academic은 제 고등학교 때 동아리 이름입니다.
academic, 아주 가끔은 저도 이랬으면 좋겠습니다.
----
academic은 제 고등학교 때 동아리 이름입니다.
academic, 아주 가끔은 저도 이랬으면 좋겠습니다.
답변 감사합니다.
답변 감사합니다. backtick을 사용해도 한글로 된 테이블명은 만들어지지 않습니다. 영문 테이블명은 잘 만들어집니다. 다른 문제가 아닐까요?
에러 메세지는 아래와 같습니다.
ERROR 1103 (42000): Incorrect table name ''
다른 문제가 있나
다른 문제가 있나 봅니다.
저는 잘 만들어지니... 일단 가능하다는 것은 말씀드릴 수 있겠네요.
--
academic은 제 고등학교 때 동아리 이름입니다.
academic, 아주 가끔은 저도 이랬으면 좋겠습니다.
----
academic은 제 고등학교 때 동아리 이름입니다.
academic, 아주 가끔은 저도 이랬으면 좋겠습니다.
mysql 설정에 좀 고쳤으면 하는 부분이 있습니다.
그리고...
mysql 설정에 좀 고쳤으면 하는 부분이 있습니다.
1.
[mysqld] 항목에서
부분은 빼는게 좋겠습니다. 대신 아래 줄을 추가하십시오.
init_connect를 이용하는 방법은 skip-character-set-client-handshake 옵션이 없을 때 사용하던 방법입니다.
2.
[mysqld] 항목에서
위 두 줄은 같은 뜻입니다. 둘 중 하나만 설정하면 됩니다. 매뉴얼에 의하면 앞으로는 character-set-server를 쓴다고 하니 character-set-server=utf8 만 남겨놓는 것이 좋겠습니다.
3.
[mysqld] 항목에 skip-character-set-client-handshake 이 설정되어 있으면 클라이언트 설정은 서버 설정을 따라 갑니다. 따라서 아래 부분은 지정해도 소용이 없습니다.
--
academic은 제 고등학교 때 동아리 이름입니다.
academic, 아주 가끔은 저도 이랬으면 좋겠습니다.
----
academic은 제 고등학교 때 동아리 이름입니다.
academic, 아주 가끔은 저도 이랬으면 좋겠습니다.
댓글 달기