백엔드 개발 PHP 튜토리얼 PDO 객체를 얻고 속성을 설정하는 방법은 무엇입니까? (자세한 코드 설명)

PDO 객체를 얻고 속성을 설정하는 방법은 무엇입니까? (자세한 코드 설명)

Mar 15, 2019 pm 01:10 PM

다른 데이터베이스 확장과 마찬가지로 PDO는 선택한 데이터에서 직접 기존 클래스의 인스턴스를 생성할 수 있습니다. 그러나 다른 확장과 달리 PDO는 강력하고 유연한 개체 조작을 위한 많은 기능을 제공합니다.

PDO 객체를 얻고 속성을 설정하는 방법은 무엇입니까? (자세한 코드 설명)

단일 객체 가져오기

쿼리 결과에서 단일 객체를 생성하려면 두 가지 방법이 있습니다.

1. 친숙한 fetch() 메소드를 사용하세요:

class User {};
$stmt = $pdo->query('SELECT name FROM users LIMIT 1');
$stmt->setFetchMode(PDO::FETCH_CLASS, 'User');
$user = $stmt->fetch();
로그인 후 복사

2. 전용 fetchObject() 메소드:

class User {};
$user = $pdo->query('SELECT name FROM users LIMIT 1')->fetchObject('User');
로그인 후 복사

두 코드 조각 모두 동일한 User 클래스 인스턴스를 제공하지만

/* object(User)#3 (1) {
  ["name"] => string(4) "John"
} */
로그인 후 복사

후자 메소드는 확실히 더 깨끗해 보입니다. 또한 fetch() 메서드를 사용했지만 클래스가 해당 이름으로 정의되지 않은 경우 배열이 자동으로 반환되는 반면 fetchObject()를 사용하면 적절한 오류가 발생합니다.

객체 배열 가져오기

물론 위에서 설명한 두 가지 방법 모두 익숙한 while 문과 함께 사용하여 데이터베이스에서 결과 행을 가져올 수 있습니다.

편리한 fetchAll() 메소드를 사용하여 객체 배열의 반환된 모든 레코드를 한 번에 가져옵니다.

class User {};
$users = $pdo->query('SELECT name FROM users')->fetchAll(PDO::FETCH_CLASS, 'User');
로그인 후 복사

는 속성을 채우는 반환된 데이터와 함께 User 클래스의 객체로 구성된 배열을 제공합니다.

/* array(2) {
  [0]=> object(User)#3 (1) {
    ["name"] => string(4) "John"
  }
  [1]=> object(User)#4 (1) {
    ["name"]=> string(4) "Mike"
  }
} */
로그인 후 복사

참고 이 패턴을 PDO::FETCH_UNIQUEPDO::FETCH_GROUP과 결합하여 고유 필드로 색인화된 결과 배열을 얻거나 고유하지 않은 필드를 사용하여 별도로 결과를 그룹화할 수 있습니다.

예를 들어 아래 코드는 연속된 숫자 대신 레코드 ID가 배열 인덱스로 사용되는 배열을 반환합니다.

class User {};
$stmt  = $pdo->query('SELECT id, id, name, car FROM users');
$users = ->fetchAll(PDO::FETCH_CLASS|PDO::FETCH_UNIQUE, 'User');
로그인 후 복사

클래스 속성 할당

어떤 방법을 선택하든 쿼리에서 반환된 모든 열은 다음 규칙에 따라 해당 클래스 속성에 할당됩니다.

1. 이름이 열과 동일합니다. 이름이 동일하면 열 값이

2 속성에 할당됩니다. 해당 속성이 없으면 __set() 매직 메서드가 호출됩니다

3. 클래스에 정의된 __set() 메서드가 없으면 공용 속성이 생성되고 열 값이 할당됩니다.

예를 들어, 이 코드

class User
{
    public $name;
}
$user = $pdo->query('SELECT * FROM users LIMIT 1')->fetchObject('User');
로그인 후 복사

는 클래스에 존재하는지 여부에 관계없이 모든 속성이 자동으로 할당된 객체를 제공합니다.

/* object(User)#3 (4) {
  ["id"]   => string(3) "104"
  ["name"] => string(4) "John"
  ["sex"]  => string(4) "male"
  ["car"]  => string(6) "Toyota"
} */
로그인 후 복사

여기에서 볼 수 있듯이 속성 자동 생성을 방지하려면 다음을 사용할 수 있습니다. 매직 메소드 __set()은 속성을 필터링합니다. 가장 간단한 필터링 기술은 빈 __set() 메서드입니다. 이를 사용하면 기존 속성만 설정됩니다.

class User
{
    private $name;
    public function __set($name, $value) {}
}
$user = $pdo->query('SELECT * FROM users LIMIT 1')->fetchObject('User');
/*
array(1) {
  [0]=> object(User)#3 (1) {
    ["name":"User":private]=> string(4) "John"
  }
} */
로그인 후 복사

위와 같이 PDO는 개인 속성에 값을 할당할 수도 있습니다.

객체에 생성자 매개변수 전달

물론 새로 생성된 객체의 경우 생성자 매개변수를 제공해야 할 수도 있습니다. 이를 위해 fetchObject()fetchAll() 메서드에는 생성자 매개변수를 배열 형식으로 전달하는 데 사용할 수 있는 전용 매개변수가 있습니다.

다음 변수를 제공하여 생성자에서 설정할 수 있는 자동차 속성이 있는 User 클래스가 있다고 가정합니다.

class User {
    public function __construct($car) {
        $this->car = $car;
    }
}
로그인 후 복사

레코드를 가져오는 동안 생성자 매개변수가 있는 배열을 추가해야 합니다.

$users = $pdo->query('SELECT name FROM users LIMIT 1')
             ->fetchAll(PDO::FETCH_CLASS, 'User', ['Caterpillar']);

$user = $pdo->query('SELECT name FROM users LIMIT 1')
            ->fetchObject('User',['Caterpillar']);
로그인 후 복사
/* object(User)#3 (2) {
    ["name"] => string(4) "John"
    ["car"]  => string(11) "Caterpillar"
} */
로그인 후 복사

좋아요, 값을 보세요 기본적으로 PDO는 생성자를 호출하기 전에 클래스 속성을 할당하기 때문에 데이터베이스에서 덮어쓰여집니다. 이는 문제가 될 수 있지만 쉽게 해결됩니다.

생성자 호출 후 클래스 속성 설정

mysql_fetch_object() 참고:

mysql_fetch_object를 사용하고 클래스를 지정하는 경우 속성은 생성자 Set에 있습니다. 함수 실행 전. 이는 일반적으로 문제가 되지 않지만, 속성이 __set() 매직 메서드를 통해 설정된 경우 생성자 논리를 먼저 수행해야 합니다. 그렇지 않으면 몇 가지 심각한 문제가 발생할 수 있습니다.

안타깝게도 mysql은 mysqli 확장이지만 우리는 PDO를 사용하고 있습니다. 그렇다면 생성자가 실행된 후 속성을 할당하도록 PDO에 지시하는 방법이 있습니까? 이를 위해서는 PDO::FETCH_PROPS_LATE 상수를 사용해야 합니다.

fetchAll()을 사용하는 것은 매우 간단합니다.

class User {
    public function __construct($car) {
        $this->car = $car;
    }
}
$stmt  = $pdo->query('SELECT name, car FROM users LIMIT 1');
$users = $stmt->fetchAll(PDO::FETCH_CLASS|PDO::FETCH_PROPS_LATE, 'User', ['Caterpillar']);
로그인 후 복사

단일 행을 가져올 때 setFetchMode()와 fetchObject()를 동시에 호출해야 하는데 이는 다소 불편할 수 있습니다.

class User {
    public function __construct($car) {
        $this->car = $car;
    }
}
$stmt = $pdo->query('SELECT name, car FROM users LIMIT 1');
$stmt->setFetchMode(PDO::FETCH_CLASS|PDO::FETCH_PROPS_LATE, 'User');
$user = $stmt->fetchObject('User', ['Caterpillar']);
/*
object(User)#3 (2) {
  ["car"]  => string(6) "Toyota"
  ["name"] => string(4) "John"
} */
로그인 후 복사

위 코드는 클래스 이름을 두 번 써야 하기 때문에 그다지 효율적이지 않습니다.

또는 fetch():

$stmt = $pdo->query('SELECT name, car FROM users LIMIT 1');
$stmt->setFetchMode(PDO::FETCH_CLASS|PDO::FETCH_PROPS_LATE, 'User', ['Caterpillar']);
$user = $stmt->fetch();
로그인 후 복사

를 사용할 수도 있습니다. 하지만 위에서 언급한 것처럼 클래스가 정의되지 않은 경우 오류 메시지를 처리하는 데 도움이 되지 않습니다.

데이터베이스에서 클래스 이름 가져오기

PDO에게 첫 번째 열의 값에서 클래스 이름을 가져오도록 지시하는 더 흥미로운 플래그도 있습니다. 이 플래그를 사용하면 setFetchMode() 및 fetch() 사용을 피할 수 있습니다.

$data = $pdo->query("SELECT 'User', name FROM users")
            ->fetch(PDO::FETCH_CLASS | PDO::FETCH_CLASSTYPE);
/*
object(User)#3 (1) {
  ["name"]=> string(4) "John"
} */
로그인 후 복사

또한 이 패턴은 동일한 쿼리에서 서로 다른 클래스의 객체를 생성할 수 있는 경우 매우 유용합니다.

class Male {};
class Female {};
$stmt = $pdo->query('SELECT sex, name FROM users');
$users = $stmt->fetchAll(PDO::FETCH_CLASS | PDO::FETCH_CLASSTYPE);
/*
array(6) {
  [0]=> object(Male)#3 (1) {
    ["name"]=> string(4) "John"
  }
  [1]=> object(Male)#4 (1) {
    ["name"]=> string(4) "Mike"
  }
  [2]=> object(Female)#5 (1) {
    ["name"]=> string(4) "Mary"
  }
  [3]=> object(Female)#6 (1) {
    ["name"]=> string(5) "Kathy"
  }
}*/
로그인 후 복사

그러나 이 패턴을 사용할 때는 , 클래스 생성자에서 매개변수를 전달하는 것이 불가능해 보입니다.

기존 개체 업데이트

除了创建新对象,PDO还可以更新现有对象。只使用setFetchMode(),它将现有变量作为参数。显然,使用fetchAll()是无用的。

class User
{
    public $name;
    public $state;

    public function __construct()
    {
        $this->name = NULL;
    }
}
$user = new User;
$user->state = "up'n'running";
var_dump($user);

$stmt = $pdo->query('SELECT name FROM users LIMIT 1');
$stmt->setFetchMode(PDO::FETCH_INTO, $user);
$data = $stmt->fetch();
var_dump($data, $user);
/*
object(Foo)#2 (2) {
  ["name"]  => NULL
  ["state"] => string(12) "up'n'running"
}
object(Foo)#2 (2) {
  ["name"]  => string(4) "John"
  ["state"] => string(12) "up'n'running"
}
object(Foo)#2 (2) {
  ["name"]  => string(4) "John"
  ["state"] => string(12) "up'n'running"
} */
로그인 후 복사

如上,fetch()调用返回的是相同的对象,这在我看来是多余的。还要注意,与PDO::FETCH_CLASS不同,这种模式不分配私有属性。

위 내용은 PDO 객체를 얻고 속성을 설정하는 방법은 무엇입니까? (자세한 코드 설명)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Laravel의 플래시 세션 데이터로 작업합니다 Laravel의 플래시 세션 데이터로 작업합니다 Mar 12, 2025 pm 05:08 PM

Laravel은 직관적 인 플래시 방법을 사용하여 임시 세션 데이터 처리를 단순화합니다. 응용 프로그램에 간단한 메시지, 경고 또는 알림을 표시하는 데 적합합니다. 데이터는 기본적으로 후속 요청에만 지속됩니다. $ 요청-

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법 PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법 Mar 14, 2025 am 11:42 AM

PHP 클라이언트 URL (CURL) 확장자는 개발자를위한 강력한 도구이며 원격 서버 및 REST API와의 원활한 상호 작용을 가능하게합니다. PHP CURL은 존경받는 다중 프로모토콜 파일 전송 라이브러리 인 Libcurl을 활용하여 효율적인 execu를 용이하게합니다.

Laravel 테스트에서 단순화 된 HTTP 응답 조롱 Laravel 테스트에서 단순화 된 HTTP 응답 조롱 Mar 12, 2025 pm 05:09 PM

Laravel은 간결한 HTTP 응답 시뮬레이션 구문을 제공하여 HTTP 상호 작용 테스트를 단순화합니다. 이 접근법은 테스트 시뮬레이션을보다 직관적으로 만들면서 코드 중복성을 크게 줄입니다. 기본 구현은 다양한 응답 유형 단축키를 제공합니다. Illuminate \ support \ Facades \ http를 사용하십시오. http :: 가짜 ([ 'google.com'=> ​​'Hello World', 'github.com'=> ​​[ 'foo'=> 'bar'], 'forge.laravel.com'=>

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트 Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트 Mar 13, 2025 pm 12:08 PM

고객의 가장 긴급한 문제에 실시간 인스턴트 솔루션을 제공하고 싶습니까? 라이브 채팅을 통해 고객과 실시간 대화를 나누고 문제를 즉시 해결할 수 있습니다. 그것은 당신이 당신의 관습에 더 빠른 서비스를 제공 할 수 있도록합니다.

PHP에서 늦은 정적 결합의 개념을 설명하십시오. PHP에서 늦은 정적 결합의 개념을 설명하십시오. Mar 21, 2025 pm 01:33 PM

기사는 PHP 5.3에 도입 된 PHP의 LSB (Late STATIC BING)에 대해 논의하여 정적 방법의 런타임 해상도가보다 유연한 상속을 요구할 수있게한다. LSB의 실제 응용 프로그램 및 잠재적 성능

프레임 워크 사용자 정의/확장 : 사용자 정의 기능을 추가하는 방법. 프레임 워크 사용자 정의/확장 : 사용자 정의 기능을 추가하는 방법. Mar 28, 2025 pm 05:12 PM

이 기사에서는 프레임 워크에 사용자 정의 기능 추가, 아키텍처 이해, 확장 지점 식별 및 통합 및 디버깅을위한 모범 사례에 중점을 둡니다.

프레임 워크 보안 기능 : 취약점 보호. 프레임 워크 보안 기능 : 취약점 보호. Mar 28, 2025 pm 05:11 PM

기사는 입력 유효성 검사, 인증 및 정기 업데이트를 포함한 취약점을 방지하기 위해 프레임 워크의 필수 보안 기능을 논의합니다.

See all articles