用接口实现的一个pdo工具类

<?php
//定义一个pdo工具类
class DAOPdo implements I_Dao
{
     //配置信息
	 private $_host;
	 private $_root;
	 private $_dbname;
	 private $_pw;
	 private $_port;
	 private $_charset;

	 //pdo对象
	 private $pdo;

	 //pdo结果集对象
	 private $result;

	 //被影响的记录数
	 private $affected_row;

     //当前类的实例化对象
     private static $instance;

	 private function __construct($option){
		 //初始化服务器配置信息
		 $this->_initArray($option);
		 //初始化pdo
		 $this->_initPdo();

	 }
     //定义一个单例模式
     public static function getSingleton(array $option=array()){
	    if(!(self::$instance instanceof self)){
		     self::$instance = new self ($option);
		  }
		  return self::$instance;
		}
	  private function __clone(){

	 }
	 private function _initArray($option){
	    $this->_host=isset($option[‘host‘])?$option[‘host‘]:‘‘;
	    $this->_pw=isset($option[‘pw‘])?$option[‘pw‘]:‘‘;
	    $this->_root=isset($option[‘root‘])?$option[‘root‘]:‘‘;
	    $this->_dbname=isset($option[‘dbname‘])?$option[‘dbname‘]:‘‘;
	    $this->_port=isset($option[‘port‘])?$option[‘port‘]:‘‘;
	    $this->_charset=isset($option[‘charset‘])?$option[‘charset‘]:‘‘;
	 }
	 private function _initPdo(){
		 try{
		 $dns="mysql:host=$this->_host;dbname=$this->_dbname;port=$this->_port;charset=$this->_charset";
         $this->pdo=new PDO($dns,$this->_root,$this->_pw);
		 }
		 //捕获异常
		 catch(PDOException $e){
		  trigger_error("数据库连接失败",E_USER_WARNING);
		  return false;
		 }
	 }
	 //用于查询的方法
     public function query($sql=‘‘){
		 if(!($this->pdo instanceof PDO)){
		    return false;
		 }
		 $result=$this->pdo->query($sql);
		 if(false==$result){
		   $error_info=$this->pdo->errorInfo();
		   $error_str="执行失败".$sql.‘----‘.$error_info[2];
		   trigger_error($error_str,E_USER_WARNING);
		   return false;
		 }else{
		 $this->result=$result;
		    return $result;
		 }
	 }
	 //用于非查询的方法
   	 public function execu($sql=‘‘){
	     if(!($this->pdo instanceof PDO)){
		    return false;
		 }
		 $result=$this->pdo->exec($sql);
		 if(false===$result){
		   $error_info=$this->pdo->errorInfo();
		   $error_str="执行失败".$sql.‘----‘.$error_info[2];
		   trigger_error($error_str,E_USER_WARNING);
		   return false;
		 }else{
		  $this->affected_row=$result;
		   return $result;
		 }
	 }
     //查询所有的记录
	 public function fetchAll($sql=‘‘){
		 $result=$this->query($sql);
		 if(false==$result){
		    return false;
		 }
      $rows=$result->fetchAll(PDO::FETCH_ASSOC);
	  $result->closeCursor();
	  return $rows;

	 }
     //查询一条记录
	 public function fetchRow($sql=‘‘){
	   $result=$this->query($sql);
	   if(false==$result){
	    return false;
	   }
	   $row=$result->fetch(PDO::FETCH_ASSOC);
	   $result->closeCursor();
	   return $row;
	 }
	 //查询某条记录第一个字段
	 public function fetchOne($sql=‘‘){
	   $result=$this->query($sql);
	   if(false==$result){
	    return false;
	   }
	   $row_one=$result->fetchColumn(4);
	   $result->closeCursor();
	   return $row_one;
	 }
	 //查询某个字段的全部数据
     public function fColumn($sql=‘‘){
		$result = $this->query($sql);
		$rows = $result->fetchAll(PDO::FETCH_COLUMN);
		return $rows;
	 }
	 //用于提供转义的方法
	 public function escapeData($data=‘‘){
	   return $this->pdo->quote($data);
	 }
	 //获取被影响的记录数
	 public function affectedRow(){
	   $affected_row=$this->affected_row;
	   return $affected_row;
	 }
	 //获取上次结果影响的记录数
	 public function resultRow(){
	   $result_row=$this->result->rowCount();

	   $this->result=null;

	    return $result_row;
	 }
	 //获取最新自动生成的ID
	 public function lastInsertId(){

	  return $this->pdo->lastInsertId();
	 }

}

?>

  

时间: 2024-10-02 13:57:49

用接口实现的一个pdo工具类的相关文章

调用CMD命令的一个.NET工具类

功能大概描述一下如果直接StandardOutput.ReadToEnd()这种方法,有很多限制 这类方式必须把命令全部执行一次写入并标记为exit,而且返回内容的获取会一直等待,如果在主线程里使用会导致假死. 若遇到执行时间长,同时会在执行中输出进度的命令,则明显不适应 对于部分特殊字符这类方法会直接中断一直等待(特别是对包含asc颜色等样式的输出) 本文的工具类解决以上问题,使用委托订阅的方式即时的输出执行过程,不用等待,异步输出结算后自动退出 方便应对类似这种需要长时间运行即时输出的打包命

用接口实现封装的一个mysqli工具类

<?php class DAOMysqli implements I_Dao{ //本类的对象实例 private static $instance; //结果集 private $result_row; //配置信息 private $_host; private $_root; private $_dbname; private $_pw; private $_port; private $_charset; //mysqli实例化对象 private $_mysqli; private f

自定义的一个JDBC工具类

package JDBCutils; import java.io.File;import java.io.FileInputStream;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.Properties; import load.l

新手写的一个DBCP工具类

1 package com.xx.questionnaire.util.dao; 2 3 import java.io.IOException; 4 import java.sql.Connection; 5 import java.sql.PreparedStatement; 6 import java.sql.ResultSet; 7 import java.sql.SQLException; 8 import java.sql.Statement; 9 import java.util.P

hibernate 配置文件 和一个 id生成类BaseEntity.java 和一个hibernate工具类 HibernatUtils.java

package com; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.junit.After; import org.junit.Before; import org.junit.Test; import com.entity.Food;

分享一个用OnGUI在手机上打印调试信息的工具类

游戏发布到手机上调试的时候有时候会需要在屏幕上打印一些信息,我写了一个小工具类,分享出来,用的是OnGUI,很简单,直接上代码了 using UnityEngine; using System.Collections; using System.Collections.Generic; public class OnGUIDebug : MonoBehaviour { public static OnGUIDebug Instance; public int FontSize = 40; pub

一个python爬虫工具类

写了一个爬虫工具类. # -*- coding: utf-8 -*- # @Time : 2018/8/7 16:29 # @Author : cxa # @File : utils.py # @Software: PyCharm from retrying import retry from decorators.decorators import decorator from glom import glom from config import headers import datetim

开源JDBC工具类DbUtils

本篇将会详细地介绍Apache公司的JDBC帮助工具类DbUtils以及如何使用.在上一篇中我们已经通过将以前对dao层使用JDBC操作数据库的冗余代码进行了简易封装形成自己的简单工具类JdbcUtils,而在这过程中很多都是借鉴和参考了DbUtils的代码,因此通过上一篇的学习,会让我们在对DbUtils进行更快速简单的认识. 俗话说学习一个开源的工具最好的方法就是看其官方文档,是的,在Apache官网中对DbUtils进行了详细的介绍:http://commons.apache.org/pr

Spring 的优秀工具类盘点第 1 部分

文件资源操作 文件资源的操作是应用程序中常见的功能,如当上传一个文件后将其保存在特定目录下,从指定地址加载一个配置文件等等.我们一般使用 JDK 的 I/O 处理类完成这些操作,但对于一般的应用程序来说,JDK 的这些操作类所提供的方法过于底层,直接使用它们进行文件操作不但程序编写复杂而且容易产生错误.相比于 JDK 的 File,Spring 的 Resource 接口(资源概念的描述接口)抽象层面更高且涵盖面更广,Spring 提供了许多方便易用的资源操作工具类,它们大大降低资源操作的复杂度