PDO类的封装
PDO类的封装
1. PDO类.rar
2. PHP代码
<?php /** * Created by tudou. * Date: 13-2-4 * Time: 下午9:57 */ /** 其他未实现的 1、绑定列到php变量请使用 $db->statement->bindColumn(1,$name); */ class pdo_class { private $pdo = null; public $statement = null; private $is_addsla = false; public $options = array( PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES ", ); public function __construct($host,$user="root",$pass="",$dbname="",$persistent=false,$charset="utf8"){ $this->options[PDO::MYSQL_ATTR_INIT_COMMAND] .= $charset; if($persistent){ $this->options[PDO::ATTR_PERSISTENT] = true; } $dsn = "mysql:host={$host};dbname={$dbname}"; $this->pdo = new PDO($dsn,$user,$pass,$this->options); } /** 全局属性设置,包括:列名格式和错误提示类型 可以使用数字也能直接使用参数 */ public function setAttr($param,$val=''){ if(is_array($param)){ foreach($param as $key=>$val){ $this->pdo->setAttribute($key,$val); } }else{ if($val!=''){ $this->pdo->setAttribute($param,$val); }else{ return false; } } } /** 生成一个编译好的sql语句模版 你可以使用 ? :name 的形式 返回一个statement对象 */ public function prepare($sql=""){ if($sql==""){ return false; } $this->statement = $this->pdo->prepare($sql); return $this->statement; } /** 执行Sql语句,一般用于 增、删、更新或者设置 返回影响的行数 */ public function exec($sql){ if($sql==""){ return false; } try{ return $this->pdo->exec($sql); }catch(Exception $e){ return $e->getMessage(); } } /** 执行有返回值的查询,返回PDOStatement 可以通过链式操作,可以通过这个类封装的操作获取数据 */ public function query($sql){ if($sql=""){ return false; } $this->statement = $this->pdo->query($sql); return $this->statement; } /** 开启事务 */ public function beginTA(){ return $this->pdo->beginTransaction(); } /** 提交事务 */ public function commit(){ return $this->pdo->commit(); } /** 事务回滚 */ public function rollBack(){ return $this->pdo->rollBack(); } public function lastInertId(){ return $db->lastInsertId(); } //** PDOStatement 类操作封装 **// /** 让模版执行SQL语句,1、执行编译好的 2、在执行时编译 */ public function execute($param=""){ if(is_array($param)){ try{ return $this->statement->execute($param); }catch (Exception $e){ //return $this->errorInfo(); return $e->getMessage(); } }else{ try{ return $this->statement->execute(); }catch(Exception $e){ /* 返回的错误信息格式 [0] => 42S22 [1] => 1054 [2] => Unknown column 'col' in 'field list' return $this->errorInfo(); */ return $e->getMessage(); } } } /** 参数1说明: PDO::FETCH_BOTH 也是默认的,两者都有(索引,关联) PDO::FETCH_ASSOC 关联数组 PDO::FETCH_NUM 索引 PDO::FETCH_OBJ 对象 PDO::FETCH_LAZY 对象 会附带queryString查询SQL语句 PDO::FETCH_BOUND 如果设置了bindColumn,则使用该参数 */ public function fetch($fetch_style=PDO::FETCH_BOTH){ if(is_object($this->statement)){ return $this->statement->fetch($fetch_style); }else{ return false; } } /** 参数1说明: PDO::FETCH_BOTH 也是默认的,两者都有(索引,关联) PDO::FETCH_ASSOC 关联数组 PDO::FETCH_NUM 索引 PDO::FETCH_OBJ 对象 PDO::FETCH_COLUMN 指定列 参数2可以指定要获取的列 PDO::FETCH_CLASS 指定自己定义的类 PDO::FETCH_FUNC 自定义类 处理返回的数据 PDO_FETCH_BOUND 如果你需要设置bindColumn,则使用该参数 参数2说明: 给定要处理这个结果的类或函数 */ public function fetchAll($fetch_style=PDO::FETCH_BOTH,$handle=''){ if($handle!=''){ return $this->statement->fetchAll($fetch_style,$handle); }else{ return $this->statement->fetchAll($fetch_style); } } /** 以对象形式返回 结果 跟fetch(PDO::FETCH_OBJ)一样 */ public function fetchObject($class_name){ if($clss_name!=''){ return $this->statement->fetchObject($class_name); }else{ return $this->statement->fetchObject(); } } /** public function bindColumn($array=array(),$type=EXTR_OVERWRITE){ if(count($array)>0){ extract($array,$type); } //$this->statement->bindColumn() } */ /** 以引用的方式绑定变量到占位符(可以只执行一次prepare,执行多次bindParam达到重复使用的效果) */ public function bindParam($parameter,$variable,$data_type=PDO::PARAM_STR,$length=6){ return $this->statement->bindParam($parameter,$variable,$data_type,$length); } /** 返回statement记录集的行数 */ public function rowCount(){ return $this->statement->rowCount(); } public function count(){ return $this->statement->rowCount(); } /** 关闭编译的模版 */ public function close(){ return $this->statement->closeCursor(); } public function closeCursor(){ return $this->statement->closeCursor(); } /** 返回错误信息也包括错误号 */ private function errorInfo(){ return $this->statement->errorInfo(); } /** 返回错误号 */ private function errorCode(){ return $this->statement->errorCode(); } //简化操作 public function insert($table,$data){ if(!is_array($data)){ return false; } $cols = array(); $vals = array(); foreach($data as $key=>$val){ $cols[]=$key; $vals[]="'".$this->addsla($val)."'"; } $sql = "INSERT INTO {$table} ("; $sql .= implode(",",$cols).") VALUES ("; $sql .= implode(",",$vals).")"; return $this->exec($sql); } public function update($table,$data,$where=""){ if(!is_array($data)){ return false; } $set = array(); foreach($data as $key=>$val){ $set[] = $key."='".trim($this->addsla($val))."'"; } $sql = "UPDATE {$table} SET "; $sql .= implode(",",$set); $sql .= " WHERE ".$where; return $this->exec($sql); } public function delete($table,$where=""){ $sql = "DELETE FROM {$table} WHERE ".$where; return $this->exec($sql); } private function addsla($data){ if($this->is_addsla){ return trim(addslashes($data)); } return $data; } }
以上就是PDO类的封装的内容,更多相关内容请关注PHP中文网(www.php.cn)!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Menurut berita dari laman web ini pada 17 April, TrendForce baru-baru ini mengeluarkan laporan, mempercayai bahawa permintaan untuk produk platform Blackwell baharu Nvidia adalah menaik, dan dijangka memacu jumlah kapasiti pengeluaran pembungkusan CoWoS TSMC meningkat lebih daripada 150% pada 2024. Produk platform baharu NVIDIA Blackwell termasuk GPU siri B dan kad pemecut GB200 yang menyepadukan CPU GraceArm NVIDIA sendiri. TrendForce mengesahkan bahawa rantaian bekalan pada masa ini sangat optimistik tentang GB200, dengan penghantaran dijangka melebihi satu juta unit pada 2025, menyumbang 40-50% daripada GPU mewah Nvidia. Nvidia merancang untuk menyampaikan produk seperti GB200 dan B100 pada separuh kedua tahun ini, tetapi pembungkusan wafer huluan mesti terus menggunakan produk yang lebih kompleks.

Laman web ini melaporkan pada 9 Julai bahawa pemproses siri "Strix" seni bina AMD Zen5 akan mempunyai dua penyelesaian pembungkusan StrixPoint yang lebih kecil akan menggunakan pakej FP8, manakala StrixHalo akan menggunakan pakej FP11. Sumber: sumber videocardz @Olrak29_ Pendedahan terbaru ialah saiz pakej FP11 StrixHalo ialah 37.5mm*45mm (1687 milimeter persegi), yang sama dengan saiz pakej LGA-1700 bagi CPU Intel AlderLake dan RaptorLake. Phoenix APU terbaru AMD menggunakan penyelesaian pembungkusan FP8 dengan saiz 25*40mm, yang bermaksud bahawa StrixHalo's F

Pengenalan kepada pengkapsulan Axios dan kaedah biasa dalam Vue Axios ialah perpustakaan HTTP berdasarkan Promise Kelebihannya ialah ia mempunyai kebolehbacaan yang baik, kemudahan penggunaan dan kebolehskalaan. Sebagai rangka kerja bahagian hadapan yang popular, Vue juga menyediakan sokongan penuh untuk Axios. Artikel ini akan memperkenalkan cara merangkum Axios dalam Vue, dan memperkenalkan beberapa kaedah Axios yang biasa digunakan. 1. Enkapsulasi Axios Semasa proses pembangunan, kita selalunya perlu melakukan beberapa enkapsulasi tersuai bagi Axios, seperti

Teknologi enkapsulasi dan enkapsulasi aplikasi dalam PHP ialah konsep penting dalam pengaturcaraan berorientasikan objek Ia merujuk kepada merangkum data dan operasi pada data bersama-sama untuk menyediakan antara muka akses bersatu kepada program luaran. Dalam PHP, enkapsulasi boleh dicapai melalui pengubahsuai kawalan akses dan definisi kelas. Artikel ini akan memperkenalkan teknologi enkapsulasi dalam PHP dan senario aplikasinya, dan menyediakan beberapa contoh kod khusus. 1. Pengubah suai kawalan capaian berkapsul Dalam PHP, pengkapsulan dicapai terutamanya melalui pengubahsuai kawalan capaian. PHP menyediakan tiga pengubah kawalan akses,

Dengan merangkum kod, fungsi C++ boleh meningkatkan kecekapan pembangunan GUI: Pengkapsulan kod: Fungsi kod kumpulan ke dalam unit bebas, menjadikan kod lebih mudah difahami dan diselenggara. Kebolehgunaan semula: Fungsi mencipta kefungsian biasa yang boleh digunakan semula merentas aplikasi, mengurangkan pertindihan dan ralat. Kod ringkas: Kod berkapsul menjadikan logik utama ringkas dan mudah dibaca serta nyahpepijat.

Cara melaksanakan enkapsulasi dan pewarisan dalam bahasa Go Enkapsulasi dan pewarisan ialah dua konsep penting dalam pengaturcaraan berorientasikan objek Ia boleh menjadikan kod lebih modular dan boleh diselenggara, dan juga memberikan kemudahan untuk penggunaan semula kod. Artikel ini akan memperkenalkan cara melaksanakan pengkapsulan dan pewarisan dalam bahasa Go dan memberikan contoh kod yang sepadan. Enkapsulasi Enkapsulasi adalah untuk merangkum data dan fungsi, menyembunyikan butiran pelaksanaan, dan hanya mendedahkan antara muka yang diperlukan untuk kegunaan luaran. Dalam bahasa Go, enkapsulasi dicapai melalui pengecam yang dieksport dan tidak dieksport. Pengecam dengan huruf besar boleh diakses oleh pakej lain

Kemahiran enkapsulasi kod PHP: Cara menggunakan kelas dan objek untuk merangkum blok kod boleh guna semula Ringkasan: Semasa pembangunan, kita sering menghadapi blok kod yang perlu digunakan semula. Untuk meningkatkan kebolehselenggaraan dan kebolehgunaan semula kod, kita boleh menggunakan teknik pengkapsulan kelas dan objek untuk merangkum blok kod ini. Artikel ini menerangkan cara menggunakan kelas dan objek untuk merangkum blok kod yang boleh digunakan semula dan menyediakan beberapa contoh kod konkrit. Kelebihan menggunakan kelas dan objek untuk merangkum Menggunakan kelas dan objek untuk merangkum mempunyai kelebihan berikut: 1.1 Meningkatkan kebolehselenggaraan kod dengan mengurangkan pertindihan.

Menurut berita dari laman web ini pada 11 Julai, Economic Daily melaporkan hari ini (11 Julai) bahawa Foxconn Group telah memasuki bidang pembungkusan lanjutan, memfokuskan pada penyelesaian semikonduktor pembungkusan kipas peringkat panel arus perdana (FOPLP). 1. Berikutan anak syarikatnya Innolux, Sharp, yang dilaburkan oleh Foxconn Group, turut mengumumkan kemasukannya ke dalam bidang pembungkusan kipas peringkat panel Jepun dan dijangka akan dikeluarkan pada 2026. Foxconn Group sendiri mempunyai pengaruh yang mencukupi dalam bidang AI, dan dengan menebus kekurangannya dalam pembungkusan lanjutan, ia boleh menyediakan perkhidmatan "sehenti" untuk memudahkan penerimaan lebih banyak pesanan produk AI pada masa hadapan. Menurut maklumat awam di laman web ini, Foxconn Group pada masa ini memegang 10.5% saham Sharp Kumpulan itu menyatakan bahawa ia tidak akan menambah atau mengurangkan pegangannya pada peringkat ini dan akan mengekalkan pegangannya.
