锟斤拷锟斤拷通锟斤拷 PDO 锟斤拷锟斤拷锟斤拷锟剿o拷锟节匡拷始锟斤拷锟叫诧拷询前锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟� PDO 锟斤拷锟斤拷喂锟斤拷锟斤拷锟斤拷锟侥★拷锟斤拷锟斤拷支锟斤拷锟侥达拷锟斤拷锟皆o拷ACID锟斤拷锟斤拷原锟斤拷锟皆o拷Atomicity锟斤拷锟斤拷一锟斤拷锟皆o拷Consistency锟斤拷锟斤拷锟斤拷锟斤拷锟皆o拷Isolation锟斤拷锟皆硷拷锟街撅拷锟皆o拷Durability锟斤拷锟斤拷通锟阶地斤拷锟斤拷锟斤拷一锟斤拷锟斤拷锟斤拷锟斤拷执锟叫碉拷锟轿何诧拷锟斤拷锟斤拷锟斤拷使锟角分阶讹拷执锟叫的o拷也锟杰憋拷证锟斤拷全锟斤拷应锟斤拷锟斤拷锟斤拷锟捷库,锟斤拷锟斤拷锟结交时锟斤拷锟斤拷锟杰碉拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟接的革拷锟脚★拷锟斤拷锟斤拷锟斤拷锟揭诧拷锟斤拷愿锟斤拷锟斤拷锟斤拷锟斤拷远锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷杌姑伙拷锟斤拷峤伙拷锟斤拷锟斤拷锟绞癸拷锟斤拷诮疟锟斤拷写锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷住锟�
锟斤拷锟斤拷通锟斤拷锟斤拷通锟斤拷锟斤拷一锟斤拷锟斤拷锟斤拷"锟斤拷锟斤拷"锟斤拷锟斤拷然锟斤拷使之同时锟斤拷效锟斤拷实锟街的o拷锟斤拷锟斤拷锟斤拷锟侥好达拷锟角匡拷锟皆达拷锟斤拷锟结供锟斤拷些锟斤拷锟侥碉拷效锟绞★拷锟斤拷锟戒话说锟斤拷锟斤拷锟斤拷锟斤拷锟绞癸拷疟锟斤拷锟斤拷欤拷锟斤拷铱锟斤拷芨锟斤拷锟阶筹拷锟斤拷锟斤拷锟斤拷锟揭拷锟饺凤拷锟绞癸拷锟斤拷锟斤拷锟斤拷锟杰伙拷锟斤拷锟斤拷锟斤拷暮么锟斤拷锟斤拷锟�
锟斤拷锟揭碉拷锟角o拷锟斤拷锟斤拷每锟斤拷锟斤拷锟捷库都支锟斤拷锟斤拷锟斤拷锟斤拷说锟斤拷锟揭伙拷未锟斤拷锟斤拷锟绞憋拷锟絇DO 锟斤拷要锟斤拷锟斤拷谓锟斤拷"锟皆讹拷锟结交"模式锟斤拷锟斤拷锟叫★拷锟皆讹拷锟结交模式锟斤拷味锟脚o拷锟斤拷锟斤拷锟斤拷菘锟街э拷郑锟斤拷锟斤拷械锟矫匡拷锟斤拷锟窖拷锟斤拷锟斤拷锟斤拷约锟斤拷锟斤拷锟绞斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟捷库不支锟斤拷锟斤拷锟斤拷锟斤拷没锟叫★拷锟斤拷锟斤拷锟揭伙拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷 PDO::beginTransaction() 锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷撞锟斤拷锟斤拷锟斤拷锟街э拷锟斤拷锟斤拷锟斤拷锟斤拷壮锟揭伙拷锟� PDOException 锟届常锟斤拷锟斤拷锟杰达拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟侥o拷锟解都锟斤拷一锟斤拷锟斤拷锟截的达拷锟斤拷状态锟斤拷锟斤拷一锟斤拷锟斤拷始锟斤拷锟斤拷锟今,匡拷锟斤拷 PDO::commit() 锟斤拷 PDO::rollBack()锟斤拷锟斤拷桑锟斤拷锟饺★拷锟斤拷锟斤拷锟斤拷锟斤拷械拇锟斤拷锟斤拷欠锟斤拷锟斤拷谐晒锟斤拷锟�
PDO 锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟角凤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷某些锟斤拷锟斤拷时锟斤拷锟斤拷锟斤拷味锟斤拷锟斤拷锟今不匡拷锟矫o拷锟斤拷锟斤拷锟捷匡拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷去锟斤拷锟斤拷一锟斤拷锟斤拷锟斤拷PDO::beginTransaction() 锟斤拷锟斤拷然锟斤拷锟斤拷 TRUE
锟斤拷锟斤拷没锟叫达拷锟斤拷
锟斤拷锟斤拷锟斤拷 MySQL 锟斤拷锟捷匡拷锟� MyISAM 锟斤拷锟捷憋拷锟斤拷使锟斤拷锟斤拷锟斤拷锟斤拷锟揭伙拷锟斤拷芎玫锟斤拷锟斤拷印锟�
锟斤拷锟脚憋拷锟斤拷锟斤拷锟斤拷锟斤拷锟接硷拷锟斤拷锟斤拷锟截憋拷时锟斤拷锟斤拷锟斤拷锟斤拷锟揭伙拷锟轿达拷锟缴碉拷锟斤拷锟斤拷锟斤拷么 PDO 锟斤拷锟皆讹拷锟截癸拷锟斤拷锟斤拷锟斤拷锟斤拷锟街帮拷全锟斤拷施锟斤拷锟斤拷锟斤拷锟节脚憋拷锟斤拷锟斤拷锟斤拷止时锟斤拷锟斤拷锟斤拷植锟揭伙拷碌锟斤拷锟斤拷——锟斤拷锟矫伙拷锟斤拷锟绞斤拷锟斤拷峤伙拷锟斤拷锟斤拷锟矫达拷锟斤拷锟斤拷锟侥筹拷锟斤拷胤锟斤拷锟斤拷锟斤拷耍锟斤拷锟斤拷锟街达拷谢毓锟斤拷锟斤拷锟街わ拷锟斤拷莅锟饺拷锟�
只锟斤拷通锟斤拷 PDO::beginTransaction() 锟斤拷锟斤拷一锟斤拷锟斤拷锟斤拷螅趴锟斤拷芊锟斤拷锟斤拷远锟斤拷毓锟斤拷锟斤拷锟斤拷锟街讹拷锟斤拷锟斤拷一锟斤拷锟斤拷询锟斤拷锟斤拷锟斤拷锟斤拷 锟斤拷 PDO 锟睫凤拷知锟斤拷锟斤拷锟接讹拷锟节憋拷要时锟斤拷锟杰斤拷锟叫回癸拷锟斤拷
Example #1 锟斤拷锟斤拷锟斤拷锟斤拷执锟斤拷锟斤拷锟斤拷锟斤拷
锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟叫o拷锟斤拷锟斤拷为锟斤拷员锟斤拷锟斤拷锟斤拷一锟斤拷锟斤拷目锟斤拷锟斤拷锟斤拷一锟斤拷为23锟斤拷ID锟斤拷锟斤拷锟剿登记达拷锟剿的伙拷锟斤拷锟斤拷锟斤拷之锟解,锟斤拷锟斤拷要锟斤拷录锟斤拷锟侥癸拷锟绞★拷锟斤拷锟斤拷锟斤拷锟铰分憋拷锟斤拷锟斤拷锟斤拷锟斤拷芗虻ィ锟斤拷锟酵拷锟斤拷锟斤拷锟斤拷 PDO::beginTransaction() 锟斤拷PDO::commit() 锟斤拷锟斤拷锟叫o拷锟斤拷锟皆憋拷证锟节革拷锟斤拷锟斤拷锟街帮拷锟斤拷锟斤拷锟斤拷锟斤拷薹锟斤拷锟斤拷锟斤拷锟叫╋拷锟斤拷摹锟斤拷锟斤拷锟斤拷锟斤拷锟剿达拷锟斤拷catch 锟斤拷毓锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷懈锟斤拷模锟斤拷锟斤拷锟斤拷一锟斤拷锟斤拷锟斤拷锟斤拷息锟斤拷
<?php
try {
$dbh = new PDO('odbc:SAMPLE', 'db2inst1', 'ibmdb2',
array(PDO::ATTR_PERSISTENT => true));
echo "Connected\n";
} catch (Exception $e) {
die("Unable to connect: " . $e->getMessage());
}
try {
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$dbh->beginTransaction();
$dbh->exec("insert into staff (id, first, last) values (23, 'Joe', 'Bloggs')");
$dbh->exec("insert into salarychange (id, amount, changedate)
values (23, 50000, NOW())");
$dbh->commit();
} catch (Exception $e) {
$dbh->rollBack();
echo "Failed: " . $e->getMessage();
}
?>
锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟叫革拷锟侥o拷也锟斤拷锟皆凤拷锟斤拷锟斤拷锟接的诧拷询锟斤拷锟斤拷取锟斤拷锟捷o拷锟斤拷锟斤拷锟斤拷使锟斤拷锟斤拷些锟斤拷息锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷母锟斤拷暮筒锟窖拷锟斤拷锟斤拷锟斤拷窦せ锟绞憋拷锟斤拷锟斤拷员锟街わ拷锟斤拷锟斤拷锟斤拷诓锟斤拷锟斤拷锟斤拷械锟斤拷锟斤拷薹锟斤拷锟斤拷锟斤拷锟斤拷摹锟斤拷锟斤拷锟斤拷一锟斤拷锟侥讹拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟较拷锟斤拷刹慰锟斤拷锟斤拷菘锟斤拷锟斤拷锟结供锟斤拷锟侥碉拷锟斤拷