>백엔드 개발 >PHP 튜토리얼 >PHP는 PDO를 사용하여 데이터베이스 왜곡 문제 솔루션 및 예제를 작동합니다.

PHP는 PDO를 사용하여 데이터베이스 왜곡 문제 솔루션 및 예제를 작동합니다.

墨辰丷
墨辰丷원래의
2018-06-04 09:56:351507검색

이 글에서는 PHP가 PDO를 사용하여 데이터베이스를 운영할 때 발생하는 잘못된 코드 문제에 대한 해결책을 주로 소개합니다. 인코딩 설정 및 속성 설정을 분석하여 잘못된 코드 문제를 예제로 해결합니다.

PDO를 사용할 때 참고할 수 있습니다. 데이터베이스를 운영하기 위해 연결에 문제가 있는 경우, 데이터베이스에 저장된 한자가 깨져 보이는 현상이 가끔 발생합니다. 파일이 UTF-8 형식인 경우 해결 방법은 다음과 같습니다.

(1) 인스턴스화된 개체는 query() 메서드 또는 exec() 메서드를 직접 실행합니다.

<?php
  class DB {
    static public function getDB() {
      try {
        $_opts_values = array(PDO::ATTR_PERSISTENT=>true,PDO::ATTR_ERRMODE=>2);
        $_pdo = new PDO(DB_DSN, DB_NAME, DB_PASS, $_opts_values);
      } catch (PDOException $e) {
        exit(&#39;数据库连接错误!错误信息:&#39;.$e->getMessage());
      }
      $_pdo->query("SET NAMES utf8"); // $_pdo->exec(&#39;SET NAMES utf8&#39;); //设置数据库编码,两种方法都可以
      return $_pdo;
    }
  }
?>

(2) 인스턴스화된 PDO 네 번째 매개변수에 MYSQL_ATTR_INIT_COMMAND 속성을 추가합니다:

<?php
  class DB {
    static public function getDB() {
      try {
        $_opts_values = array(PDO::ATTR_PERSISTENT=>true,PDO::ATTR_ERRMODE=>2,PDO::MYSQL_ATTR_INIT_COMMAND=>&#39;SET NAMES utf8&#39;);
        $_pdo = new PDO(DB_DSN, DB_NAME, DB_PASS, $_opts_values);
      } catch (PDOException $e) {
        exit(&#39;数据库连接错误!错误信息:&#39;.$e->getMessage());
      }
      return $_pdo;
    }
  }
?>

요약: 위 내용은 이 기사의 전체 내용입니다. 모든 사람의 학습에 도움이 되기를 바랍니다.

관련 추천:

PHP 정규식 기본 소개

php UEditor Baidu 편집기 설치 및 사용 공유

PHP swoole 확장 설치 방법 및 자세한 튜토리얼

위 내용은 PHP는 PDO를 사용하여 데이터베이스 왜곡 문제 솔루션 및 예제를 작동합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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