MySQLi의 경우 트랜잭션과 준비된 명령문은 물론 MySQL 확장을 제거할 수 있는 자본입니다. 우리는 이전에 PDO의 트랜잭션과 준비된 명령문에 대해서도 배웠습니다. 따라서 여기서는 더 이상 이론에 대해 이야기하지 않고 직접 코드로 이동하여 MySQLi와 PDO에서 이 두 기능의 사용 차이를 살펴보겠습니다.
트랜잭션 처리
우선, MySQLi도 잘못된 명령문에 대한 예외를 보고하도록 해야 합니다. 이 기능은 PDO와 매우 다릅니다. PDO에서는 연결의 오류 보고 속성을 직접 지정할 수 있습니다. MySQLi에서는 예외를 발생시키려면 MySQLi_Driver 객체에 오류 속성을 지정해야 합니다. 분명히 MySQLi_Driver는 MySQLi의 드라이버 객체입니다.
// 使用异常处理错误情况 $driver = new mysqli_driver(); $driver->report_mode = MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT;
이것은 MySQLi 확장을 사용할 때 모든 오류 메시지가 예외로 발생하도록 지정합니다.
다음 내용은 실제로 PDO와 매우 유사합니다.
try { // 开始事务 $mysqli->begin_transaction(); $mysqli->query("insert into tran_innodb (name, age) values ('Joe', 12)"); $mysqli->query("insert into tran_innodb2 (name, age) values ('Joe', 12)"); // 不存在的表 // 提交事务 $mysqli->commit(); } catch (Exception $e) { // 回滚事务 $mysqli->rollback(); var_dump($e->getMessage()); // string(44) "Table 'blog_test.tran_innodb2' doesn't exist" }
또한 트랜잭션을 시작하기 위해 Begin_transaction()을 사용합니다. 그런 다음 commint() 메서드를 통해 트랜잭션을 커밋합니다. 이 테스트 코드에서 두 번째 SQL 문은 오류를 보고하므로 catch에 들어가고 rollback()을 사용하여 트랜잭션을 롤백합니다.
문 전처리
일반적으로 트랜잭션 처리와 PDO는 큰 차이가 없으나, 준비된 문을 사용하는 방식과 PDO에는 약간의 차이가 있습니다. 첫 번째는 MySQLi의 자리 표시자가 ? 물음표 자리 표시자일 뿐이라는 것입니다. 또한, PDO의 BindValue() 메소드와 유사하지 않은 것은 단지 PDO의'bind_param()'뿐입니다.
$stmt = $mysqli->prepare("select * from zyblog_test_user where username = ?"); $username = 'aaa'; $stmt->bind_param("s", $username); // 绑定参数 $stmt->execute(); // 执行语句 $aUser = $stmt->fetch(); // 获取mysqli_result结果集对象 $username='bbb'; $stmt->bind_param('s', $username); $stmt->execute(); $bUser = $stmt->fetch(); var_dump($aUser); // array(4) { // ["id"]=> // int(1) // ["username"]=> // string(3) "aaa" // ["password"]=> // string(3) "aaa" // ["salt"]=> // string(3) "aaa" // } var_dump($bUser); // array(4) { // ["id"]=> // int(2) // ["username"]=> // string(3) "bbb" // ["password"]=> // string(3) "bbb" // ["salt"]=> // string(3) "123" // }
코드에서 볼 수 있듯이,bind_param() 메소드의 사용도 PDO와 매우 다릅니다. 아래첨자가 필요하지 않지만 s 매개변수가 제공됩니다. 이 매개변수는 바인딩된 데이터의 유형을 나타내며, s는 문자열 유형입니다. 다른 유형에 대해서는 MySQLi_STMT 관련 내용을 공부할 때 더 자세히 알아볼 것입니다.
요약
사실 코드 수준에서 보면 대부분의 내용이 PDO와 매우 유사하지만 일부 매개변수가 다릅니다. 우리에게는 MySQLi를 기본 데이터베이스 작업으로 사용하는 일부 프레임워크를 캡슐화하거나 사용할 때 혼란을 피하기 위해 여전히 학습과 이해에 관한 것입니다.
테스트 코드:
https://github.com/zhangyue0503/dev-blog/blob/master/php/202009/source/7.PHP中的MySQLi扩展学习(四)mysqli的事务与预处理语句.php
추천 학습: php 비디오 튜토리얼
위 내용은 PHP에서 mysqli 트랜잭션과 준비된 문을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사는 산 및 기본 데이터베이스 모델을 비교하여 특성과 적절한 사용 사례를 자세히 설명합니다. 산은 금융 및 전자 상거래 애플리케이션에 적합한 데이터 무결성 및 일관성을 우선시하는 반면 Base는 가용성 및

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.

기사는 내장 함수 사용, 화이트리스트 접근 방식 및 서버 측 유효성 검사와 같은 기술에 중점을 둔 보안을 향상시키기 위해 PHP 입력 유효성 검증에 대한 모범 사례를 논의합니다.

이 기사는 토큰 버킷 및 누출 된 버킷과 같은 알고리즘을 포함하여 PHP에서 API 요율 제한을 구현하고 Symfony/Rate-Limiter와 같은 라이브러리 사용 전략에 대해 설명합니다. 또한 모니터링, 동적 조정 요율 제한 및 손도 다룹니다.

이 기사에서는 PHP에서 암호를 보호하기 위해 PHP에서 Password_hash 및 Password_Verify 사용의 이점에 대해 설명합니다. 주요 주장은 이러한 기능이 자동 소금 생성, 강한 해싱 알고리즘 및 Secur를 통해 암호 보호를 향상 시킨다는 것입니다.

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

이 기사는 PHP의 XSS 공격을 방지하기위한 전략, 입력 소독, 출력 인코딩 및 보안 향상 라이브러리 및 프레임 워크 사용에 중점을 둔 전략에 대해 설명합니다.

이 기사는 각각의 사용시기에 중점을 둔 PHP의 인터페이스 및 추상 클래스 사용에 대해 설명합니다. 인터페이스는 관련없는 클래스 및 다중 상속에 적합한 구현없이 계약을 정의합니다. 초록 클래스는 일반적인 기능을 제공합니다


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

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