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 중국어 웹사이트의 기타 관련 기사를 참조하세요!