>백엔드 개발 >PHP 튜토리얼 >PDO 생성자를 사용하여 데이터베이스 및 DSN에 연결하는 방법에 대한 자세한 설명

PDO 생성자를 사용하여 데이터베이스 및 DSN에 연결하는 방법에 대한 자세한 설명

黄舟
黄舟원래의
2017-04-28 17:37:164490검색

PDO 생성자를 사용하여 데이터베이스 및 DSN에 연결하는 방법에 대한 자세한 설명

pdo는 문제를 해결하기 위해 php5에 새로 추가된 데이터베이스 추상화 계층입니다. 다양한 데이터베이스의 통합 인터페이스에 액세스합니다. PEAR::DB 클래스, ADODB 클래스의 동작과 유사하지만 PHP 확장에 직접 캡슐화되어 자유롭게 사용할 수 있습니다.

이전 글에서 "PDO란? "PDO 특성 개요 및 PDO 설치 방법"에서는 PDO가 무엇인지 소개하고 PDO의 특성과 설치 방법을 소개했기 때문에 이번 글에서는 데이터베이스에 연결하는 PDO 생성자와 DSN 세부 정보를 소개합니다!

PDO 생성자가 데이터베이스에 연결합니다.

PDO에서 데이터베이스 연결을 설정하려면 PDO 생성자를 인스턴스화해야 합니다. 구문 형식은 다음과 같습니다.

_construct(string $dsn[,string $username[,string $password[,array $driver_options]]])

생성자의 매개변수 설명은 다음과 같습니다.

dsn: 호스트 이름, 포트 번호 및 데이터베이스 이름을 포함한 데이터 소스 이름입니다.

사용자 이름: 데이터베이스에 연결하기 위한 사용자 이름입니다.

password: 데이터베이스에 연결하기 위한 비밀번호입니다.

driver_options: 데이터베이스 연결을 위한 기타 옵션입니다.

그런 다음 PDO를 통해 MySQL 데이터베이스에 연결하는 예를 들어 직접 설명하겠습니다. 구체적인 코드는 다음과 같습니다.

<?php
header("Content-Type:text/html; charset=utf-8");    //设置页面的编码格式
$dbms = "mysql";                                  // 数据库的类型
$dbName ="php_cn";                                //使用的数据库名称
$user = "root";                                   //使用的数据库用户名
$pwd = "root";                                    //使用的数据库密码
$host = "localhost";                              //使用的主机名称
$dsn  = "$dbms:host=$host;dbName=$dbName ";       
try{                                             //捕获异常
    $pdo = new PDO($dsn,$user,$pwd);             //实例化对象
    echo  "PDO连接数据库成功";
}catch (Exception $e){
    echo $e->getMessage()."<br>";
}

페이지에서 출력되는 결과는 다음과 같습니다.

PDO 생성자를 사용하여 데이터베이스 및 DSN에 연결하는 방법에 대한 자세한 설명

참고: 위 필드 중 하나라도 잘못 입력된 경우 try catch 문을 통해 예외가 발생합니다!

DSN 상세 설명

DSN이란?

DSN은 Data Source Name의 약자입니다. DSN은 데이터베이스에 연결하는 데 필요한 정보를 제공합니다. PDO의 DSN은 PDO 드라이버 이름(예: mysql, sqlite 또는 pgsql), 콜론 및 드라이버별 구문의 세 부분으로 구성됩니다. 각 데이터베이스에는 고유한 특정 드라이버 구문이 있습니다.

다른 데이터베이스를 사용하는 경우 데이터베이스 서버가 PHP와 완전히 독립된 개체라는 점을 분명히 해야 합니다. 그러나 실제 상황에서는 데이터베이스 서버와 웹 서버가 동일한 컴퓨터에 있지 않을 수 있습니다. 이 경우 PDO를 통해 데이터베이스에 연결해야 하는 경우 DSN에서 호스트 이름을 수정합니다.

데이터베이스 서버는 특정 포트의 연결 요청만 수신하기 때문입니다. 각 데이터베이스 서버에는 기본 포트 번호(MySQL은 3306)가 있지만 데이터베이스 관리자가 포트 번호를 수정할 수 있으므로 PHP가 데이터베이스의 포트 번호를 찾지 못할 가능성이 있습니다. DSN. 예:

$dsn="mysql:host=127.0.0.1;port=3306;dbname=admin";

한 데이터베이스에 동시에 여러 데이터베이스가 있을 수 있으므로 DSN을 통해 데이터베이스에 연결할 때 일반적으로 데이터베이스 이름이 포함됩니다. 이렇게 하면 사용자가 원하는 데이터베이스가 보장될 수 있습니다. 다른 데이터베이스가 아닌 연결되었습니다.

PDO 생성자를 사용하여 데이터베이스와 DSN을 연결하는 방법을 자세히 소개합니다. 그런 다음 PDO에서 SQL 문을 실행하는 몇 가지 방법을 소개합니다. "PDO에서 SQL문을 실행하는 세 가지 방법"을 읽어보세요!

위 내용은 PDO 생성자를 사용하여 데이터베이스 및 DSN에 연결하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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