> 백엔드 개발 > PHP 문제 > PHP가 표시하는 데이터베이스의 중국어 왜곡 문자를 해결하는 방법

PHP가 표시하는 데이터베이스의 중국어 왜곡 문자를 해결하는 방법

PHPz
풀어 주다: 2023-04-21 09:32:14
원래의
982명이 탐색했습니다.

개발 중에 PHP를 사용하여 데이터베이스를 호출할 때 중국어 문자가 깨지는 문제에 자주 직면합니다. 이 문제는 일반적으로 데이터베이스 문자 집합이 PHP 문자 집합과 다르거나 PHP가 데이터베이스의 중국어 문자를 올바르게 구문 분석하지 못하기 때문에 발생합니다. 이번 글에서는 PHP에서 한자가 깨지는 문제를 해결하는 방법을 소개하겠습니다.

1. 데이터베이스 문자 집합 구성

1.1 데이터베이스 문자 집합 보기
데이터베이스의 현재 문자 집합을 보려면 명령줄 인터페이스에 다음 명령을 입력하세요.

show variables like 'character%';
로그인 후 복사

1.2 데이터베이스 문자 집합 설정
중국어 문자 깨짐 문제를 해결하려면 데이터베이스 문자 집합을 utf8로 변경해야 합니다. mysql에서는 다음 명령을 사용하여 설정할 수 있습니다.

ALTER DATABASE `database_name` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
로그인 후 복사

여기서 database_name은 설정하려는 데이터베이스의 이름입니다. 여기서 데이터베이스의 기본 문자 집합은 utf8로 설정됩니다. MySQL에서 utf8은 가장 일반적으로 사용되는 문자 집합이며 대부분의 언어에서 문자를 지원할 수 있습니다. database_name是你要设置的数据库名称。这里将数据库的默认字符集设置为utf8。在mysql中,utf8是最常用的字符集,能够支持绝大多数语言的字符。

1.3 设置数据表字符集
在mysql中,每个数据表也可以单独设置字符集。通过以下命令可以将某个表的字符集设置为utf8:

ALTER TABLE `table_name` CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;
로그인 후 복사

其中,table_name

1.3 데이터 테이블의 문자 집합을 설정합니다.

mysql에서는 각 데이터 테이블마다 독립적으로 문자 집합을 설정할 수도 있습니다. 다음 명령을 통해 테이블의 문자 집합을 utf8로 설정할 수 있습니다.

mbstring.language=CN
로그인 후 복사

여기서 table_name은 설정하려는 데이터 테이블의 이름입니다. 여기서 데이터 테이블의 문자 집합은 utf8로 설정됩니다. 이런 방식으로 데이터베이스의 모든 테이블은 utf8 문자 집합을 사용합니다.

2. PHP 문자 집합 설정


2.1 PHP 기본 문자 집합 설정

php.ini 파일을 열고 "mbstring.언어" 매개변수를 찾아 해당 값을 "CN"으로 설정합니다. 아래와 같이:

header('content-type:text/html;charset=utf-8');
로그인 후 복사
2.2 PHP 런타임 문자 집합 설정

PHP에서는 런타임 문자 집합도 설정해야 합니다. 다음 코드를 통해 PHP의 문자 집합을 설정할 수 있습니다.

$conn = mysql_connect($dbhost, $dbuser, $dbpass) or die('连接数据库失败!');
mysql_select_db($dbname, $conn);
mysql_query("SET NAMES 'utf8'");
로그인 후 복사

이 코드는 PHP의 출력 문자 집합을 UTF-8로 설정합니다.

3. 데이터베이스에서 한자를 호출합니다

3.1 데이터베이스 링크 문자 집합

PHP에서는 데이터베이스에 연결할 때 문자 집합을 설정해야 합니다.

mysql_query("set character_set_client=utf8");
mysql_query("set character_set_results=utf8");
로그인 후 복사
그 중 $dbhost, $ dbuser, $dbpass, $ dbname은 각각 데이터베이스의 호스트 주소, 사용자, 비밀번호 및 데이터베이스 이름입니다. 여기서는 mysql_query() 함수를 통해 데이터베이스 문자 집합을 utf8로 설정했습니다.
  1. 3.2 쿼리 문자셋 설정
    쿼리에 한자가 포함된 경우 쿼리 문자셋을 설정해야 합니다. 다음 코드를 통해 쿼리 문자 집합을 설정할 수 있습니다.
  2. $result = mysql_query("SELECT * FROM table_name");
    while($row = mysql_fetch_array($result)){
        echo $row['field_name'];
    }
    로그인 후 복사

테스트 결과

데이터베이스 문자 집합과 PHP 문자 집합을 구성한 후 데이터베이스에서 중국어를 테스트할 수 있습니다. 테이블을 생성하고 한자를 삽입한 후 다음 코드로 볼 수 있습니다.

rrreee

이렇게 하면 한자가 페이지에 올바르게 표시됩니다.

🎜5. 요약🎜🎜위 단계를 통해 PHP 디스플레이 데이터베이스의 중국어 문자 깨짐 문제를 해결할 수 있습니다. 한자를 올바르게 표시하기 위해서는 데이터베이스 문자셋과 PHP 문자셋을 모두 utf8로 설정하고, 쿼리 문자셋과 링크 문자셋을 올바르게 설정해야 합니다. 이런 식으로 한자를 개발에 사용하고 올바르게 표시할 수 있습니다. 🎜

위 내용은 PHP가 표시하는 데이터베이스의 중국어 왜곡 문자를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿