Notes 004 PHP POD 연구 노트 03
1. 연결 설정
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
? ;
2. 연결 오류 처리
try {
$dbh = new PDO( 'mysql :host=localhost;dbname=test', $user, $pass);
foreach($dbh->query('SELECT * from FOO') as $row) {
print_r($row );
}
$dbh = null;
} catch (PDOException $e) {
print "Error!: " . $e->getMessage() "
die();
}
?>
연결 끊기
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
// 여기서 연결 사용
// 이제 실행이 완료되었습니다. $dbh = null; ?>
트랜잭션
모든 데이터베이스 트랜잭션이 지원되는 것은 아닙니다. , 따라서 PDO는 연결이 처음 열릴 때 소위 "자동 커밋" 모드에서 실행되어야 합니다. 자동 커밋 모드는 데이터베이스가 지원하는 경우 각 쿼리 실행에 자체 암시적 트랜잭션이 있고 데이터베이스가 트랜잭션을 지원하지 않는 경우에는 없음을 의미합니다. 트랜잭션이 필요한 경우 PDO::beginTransaction() 메서드를 사용하여 시작해야 합니다. 기본 드라이버가 트랜잭션을 지원하지 않으면 PDOException이 발생합니다(이는 오류 처리 설정에 관계없이 심각한 오류 조건입니다). 트랜잭션이 시작되면 트랜잭션의 코드가 성공적으로 실행되었는지 여부에 따라 PDO::commit() 또는 PDO::rollBack()을 사용하여 완료할 수 있습니다.
스크립트가 종료되거나 연결이 닫히려고 할 때 완료되지 않은 트랜잭션이 있으면 PDO가 자동으로 트랜잭션을 롤백합니다. 이 안전 조치는 스크립트가 예기치 않게 종료되는 경우 불일치를 방지하는 데 도움이 됩니다. 트랜잭션이 명시적으로 커밋되지 않은 경우 문제가 발생한 것으로 가정하므로 데이터를 안전하게 유지하기 위해 롤백이 수행됩니다.
다음 예에서는 새 직원에 대한 항목 집합이 생성되고 ID 23이 할당되었다고 가정합니다. 개인의 기본 데이터를 등록하는 것 외에도 급여를 기록하는 것도 필요합니다. 두 업데이트를 개별적으로 수행하는 것은 간단하지만 PDO::beginTransaction() 및 PDO::commit() 호출에 포함하면 완료될 때까지 다른 사람이 변경 사항을 볼 수 없도록 할 수 있습니다. 오류가 발생하면 catch 블록은 트랜잭션이 시작된 이후 발생한 모든 변경 사항을 롤백하고 오류 메시지를 인쇄합니다.
시도해 보세요. {
$dbh = new PDO('odbc:SAMPLE', 'db2inst1', 'ibmdb2',
array(PDO::ATTR_PERSISTENT => true));
echo "Connectedn";
} catch (Exception $e) {
die("연결할 수 없습니다: " . $e->getMessage ());
}
{
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$dbh->를 시도하세요. ;beginTransaction(); $dbh->exec("직원(ID, 이름, 마지막) 값에 삽입 (23, 'Joe', 'Bloggs')") $dbh->exec("insert into 급여 변경( ID, 금액, 변경 날짜) 값 (23, 50000, NOW())"); $dbh->commit();
} catch(예외 $e) { $dbh-> ;rollBack() ; echo "Failed: " . $e->getMessage() } ?>
위는 Note 004 PHP POD Study Note 03의 내용입니다. PHP 중국어 홈페이지(www.php.cn)를 주목해주세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다
