Excel 및 MySQL과 상호 작용할 때 잘못된 문자를 해결하는 방법

WBOY
풀어 주다: 2023-06-03 12:04:59
앞으로
1196명이 탐색했습니다.

1. 이유

1. 문자 집합 불일치: Excel의 기본 문자 집합은 GB2312인 반면 MySQL의 기본 문자 집합은 UTF-8 또는 GBK이므로 전송 중에 데이터가 깨질 수 있습니다.

2. 데이터 유형 불일치: MySQL의 VARCHAR 및 TEXT 유형 필드는 서로 다른 문자 집합을 저장할 수 있지만 Excel의 셀은 하나의 문자 집합만 지원합니다. Excel 셀에 다른 문자 집합이 포함되어 있으면 잘못된 문자가 나타날 수 있습니다.

3. 일관되지 않은 파일 인코딩: Excel을 사용하여 CSV 형식의 파일을 열거나 저장할 때 일관되지 않은 인코딩이 발생할 수 있습니다. 예를 들어, CSV 파일을 저장할 때 ANSI 인코딩을 선택했는데 MySQL이 UTF-8 인코딩을 사용하는 경우 전송 중에 데이터가 깨질 수 있습니다.

2. 솔루션

MySQL에 연결할 때 일관되지 않은 문자 세트로 인해 문자가 깨지는 것을 방지하려면 문자 세트를 GB2312로 설정하여 문자 세트를 일관되게 유지해야 합니다. 다음 매개변수를 MySQL 커넥터/ODBC에 추가할 수 있습니다:

charset=GB2312

2. 데이터 유형 일치: MySQL 데이터 테이블을 생성할 때 VARCHAR 및 TEXT 유형 필드를 GB2312 문자 집합으로 지정할 수 있습니다. 예:

CREATE TABLE test (
id INT NOT NULL,
name VARCHAR(30) CHARACTER SET GB2312 DEFAULT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;

파일 인코딩을 유지하려면 일관되게 Excel을 사용하여 CSV 파일을 저장할 때 UTF-8 인코딩을 선택해야 합니다. 예를 들어, "파일" -> "다른 이름으로 저장"을 클릭하고 "CSV UTF-8(쉼표로 구분)" 형식을 선택하여 Excel에 파일을 저장할 수 있습니다.

또한 때로는 SET NAMES 명령을 사용하여 MySQL에서 문자 집합을 설정할 수도 있습니다. 예:

SET NAMES 'GB2312'.

위 내용은 Excel 및 MySQL과 상호 작용할 때 잘못된 문자를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!