ホームページ >バックエンド開発 >PHPチュートリアル >PHP PDO データベース操作クラス

PHP PDO データベース操作クラス

WBOY
WBOYオリジナル
2016-07-25 08:42:001109ブラウズ

シンプルな PDO クラス パッケージ。 。学習とコミュニケーションのみを目的としています

PdoDb データベース クラス

  1. /**
  2. * @throws エラー
  3. * PDO データベース
  4. */
  5. class PdoDb extends DatabaseAbstract
  6. {
  7. /**
  8. * PDO インスタンス
  9. * @var PDO
  10. */
  11. protected $DB;
  12. /**
  13. * PDO 準備済みステートメント
  14. * @var PDOStatement
  15. */
  16. protected $Stmt;
  17. /**
  18. * 最後の SQL ステートメント
  19. * @var 文字列
  20. */
  21. protected $Sql;
  22. /**
  23. * 構成情報 $config=array('dsn'=>xxx,'name'=>xxx,'password'=>xxx,'option'=>xxx)
  24. * @var array
  25. */
  26. protected $Config;
  27. /**
  28. * コンストラクター
  29. * @param array $config
  30. */
  31. public function __construct($config)
  32. {
  33. $this->Config = $config;
  34. }
  35. /**
  36. * データベースに接続します
  37. * @return void
  38. */
  39. public function connect()
  40. {
  41. $this->DB = new PDO($this->Config[ 'dsn'], $this->Config['name'], $this->Config['password'], $this->Config['option']);
  42. //默认握结果順序列化成stdClass
  43. $this->DB->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
  44. //自己写代码捕获Exception
  45. $this->DB->setAttribute(PDO::ATTR_ERRMODE, PDO ::ERRMODE_SILENT);
  46. }
  47. /**
  48. * 切断
  49. * @return void
  50. */
  51. public function disConnect()
  52. {
  53. $this->DB = null;
  54. $this->Stmt = null;
  55. }
  56. / **
  57. * SQLを実行し、新しく追加されたIDを返します
  58. * @param string $statement
  59. * @return string
  60. */
  61. public function exec($statement)
  62. {
  63. if ($this->DB->exec($statement)) {
  64. $this->Sql = $statement;
  65. return $ this->lastId();
  66. }
  67. $this->errorMessage();
  68. }
  69. /**
  70. * クエリsql
  71. * @param string $statement
  72. * @return PdoDb
  73. */
  74. public function query($statement)
  75. {
  76. $res = $this-> ;DB->query($statement);
  77. if ($res) {
  78. $this->Stmt = $res;
  79. $this->Sql = $statement;
  80. return $this;
  81. }
  82. $this ->errorMessage();
  83. }
  84. /**
  85. * データを一度シリアル化します
  86. * @returnmixed
  87. */
  88. public function fetchOne()
  89. {
  90. return $this->Stmt->fetch();
  91. }
  92. /**
  93. * すべてのデータをシリアル化します
  94. * @return array
  95. */
  96. public function fetchAll()
  97. {
  98. return $this->Stmt->fetchAll();
  99. }
  100. /**
  101. * 最後に追加されたID
  102. * @return string
  103. */
  104. public function lastId()
  105. {
  106. return $ this->DB->lastInsertId();
  107. }
  108. /**
  109. * 影響を受ける行数
  110. * @return int
  111. */
  112. public functionaffectRows()
  113. {
  114. return $this->Stmt->rowCount();
  115. }
  116. /**
  117. * 準備されたステートメント
  118. * @param string $statement
  119. * @return PdoDb
  120. */
  121. public function prepare($statement)
  122. {
  123. $res = $this->DB->prepare($statement);
  124. if ($res) {
  125. $this-> ;Stmt = $res;
  126. $this->Sql = $statement;
  127. return $this;
  128. }
  129. $this->errorMessage();
  130. }
  131. /**
  132. * バインドデータ
  133. * @param array $array
  134. * @return PdoDb
  135. */
  136. public function bindingArray ($array)
  137. {
  138. foreach ($array as $k => $v) {
  139. if (is_array($v)) {
  140. //配列の有能な配列 array('value'=>xxx,'type'=>PDO::PARAM_XXX)
  141. $this->Stmt- >bindValue($k + 1, $v['value'], $v['type']);
  142. } else {
  143. $this->Stmt->bindValue($k + 1, $v, PDO::PARAM_STR);
  144. }
  145. }
  146. return $this;
  147. }
  148. /**
  149. * 準備されたステートメントを実行します
  150. * @return bool
  151. */
  152. public functionexecute()
  153. {
  154. if ($this->Stmt->execute() ) {
  155. return true;
  156. }
  157. $this->errorMessage();
  158. }
  159. /**
  160. * トランザクションを開始します
  161. * @return bool
  162. */
  163. public function beginTransaction()
  164. {
  165. return $this->DB->beginTransaction ();
  166. }
  167. /**
  168. *トランザクションを実行します
  169. * @return bool
  170. */
  171. public function commitTransaction()
  172. {
  173. return $this->DB->commit();
  174. }
  175. /**
  176. * トランザクションのロールバック
  177. * @return bool
  178. */
  179. public function rollbackTransaction()
  180. {
  181. return $this->DB->rollBack();
  182. }
  183. /**
  184. * エラーをスローします
  185. * @throws エラー
  186. * @return void
  187. */
  188. public function errorMessage( )
  189. {
  190. $msg = $this->DB->errorInfo();
  191. throw new Error('数据库错误:' . $msg[2]);
  192. }
  193. //------ ---------------
  194. /**
  195. * シングルトン インスタンス
  196. * @var PdoDb
  197. */
  198. protected static $_instance;
  199. /**
  200. * デフォルトデータベース
  201. * @static
  202. * @param array $config
  203. * @return PdoDb
  204. */
  205. public static function インスタンス($config)
  206. {
  207. if (!self::$_instance instanceof PdoDb) {
  208. self::$_instance = new PdoDb($config);
  209. self::$_instance->connect();
  210. }
  211. return self::$_instance ;
  212. }
  213. //----------------------
  214. /**
  215. * PDO でサポートされているデータベースを取得します
  216. * @static
  217. * @return array
  218. */
  219. public static function getSupportDriver(){
  220. return PDO ::getAvailableDrivers();
  221. }
  222. /**
  223. * データベースのバージョン情報を取得します
  224. * @return array
  225. */
  226. public function getDriverVersion(){
  227. $name = $this->DB->getAttribute(PDO::ATTR_DRIVER_NAME);
  228. return array($ name=>$this->DB->getAttribute(PDO::ATTR_CLIENT_VERSION));
  229. }
  230. }
复制代

使用する時期

  1. PdoDb::instance($config);
复制代
PHP、PDO


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。