## PDO 介紹
事務四大特性(ACID):原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)以及持久性(Durability)。
在一個事務中執行的任何操作,即使是分階段執行的,也能保證安全地應用于數據庫,并在提交時不會受到來自其他連接的干擾。事務操作也可以根據請求自動撤銷(假設還沒有提交),這使得在腳本中處理錯誤更加容易。
```
<?php
try {
$pdo = new PDO('mysql:host=localhost;dbname=koogua_forum', 'root', '123456');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {
echo "Connect Failed: " . $e->getMessage();
}
try {
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$pdo->beginTransaction();
$stmt = $pdo->prepare("INSERT INTO TagWatch (userId, tagId) VALUES (:userId, :tagId)");
$stmt->bindValue(':userId', 1, PDO::PARAM_INT);
$stmt->bindValue(':tagId', 1, PDO::PARAM_INT);
$stmt->execute();
$stmt = $pdo->prepare("UPDATE Tag SET watchCount = watchCount + 1 WHERE id = :id");
$stmt->bindValue(':id', 1, PDO::PARAM_INT);
$stmt->execute();
$pdo->commit();
} catch (PDOException $e) {
$pdo->rollBack();
echo "Commit Failed: " . $e->getMessage();
}
?>
```
參考鏈接:[PDO 事務處理](http://php.net/manual/zh/pdo.transactions.php)
- 基本語法
- PHP標記
- 指令分隔符
- 從HTML中分離
- 注釋
- 數據類型
- 布爾值
- 整數
- 浮點數
- 字符串
- 數組
- 對象
- 資源
- 空值
- 變量
- 基礎
- 預定義變量
- 變量范圍
- 可變變量
- 常量
- 常量語法
- 魔術常量
- 運算符
- 算術運算符
- 賦值運算符
- 位運算符
- 比較運算符
- 遞增與遞減運算符
- 邏輯運算符
- 字符串運算符
- 數組運算符
- 類型運算符
- 流程控制
- if條件結構
- switch條件結構
- while循環結構
- do-while循環結構
- for循環結構
- foreach循環結構
- 包含文件
- 函數
- 自定義函數
- 可變函數
- 匿名函數
- 遞歸函數
- 類與對象
- 基本概念
- 屬性
- 方法
- 類常量
- 構造函數和析構函數
- 訪問控制
- 繼承
- 抽象類
- 接口
- Trait
- 重載
- 對象遍歷
- 魔術方法
- Final關鍵字
- 命名空間
- 自動加載
- 錯誤處理
- 錯誤顯示
- 錯誤日志
- 錯誤報告
- 自定義錯誤處理
- 異常處理
- 異常處理機制
- 擴展異常處理類
- 字符操作
- 數組操作
- 時間操作
- 表單操作
- GET提交
- POST提交
- 文件上傳
- 會話控制
- COOKIE操作
- SESSION操作
- 文件操作
- 文件屬性
- 讀取文件
- 寫入文件
- 文件管理
- 文件鎖
- 目錄處理
- 路徑處理
- 網絡操作
- HTTP協議
- Socket操作
- CURL操作
- PDO操作
- 介紹
- 連接管理
- 預處理語句
- 事務處理
- 錯誤處理
- 圖像操作
- 正則表達式
- 標準推薦
- 包管理器
- 設計模式
- 常用算法
- 安全防御
- XSS防御
- CSRF防御