Maison développement back-end tutoriel php PHP有用的MYSQL操作类(设计模式解读一)_PHP教程

PHP有用的MYSQL操作类(设计模式解读一)_PHP教程

Jul 13, 2016 pm 05:51 PM
mysql php un 入门 操作 数据库 avoir pratique 简单 Voulez-vous utiliser 解读 设计模式

要用PHP操作一个数据库很简单,相应入门后的PHPER都可以做到,但是在应对大量的表操作时,我们为许多的MYSQL语句感到厌烦,所以我们急切想要把大量数据库操作封装起来。所以就出现了数据库对象映射。

首先我们新建一个接口。

singleton.class.php
[php]
/**
 * @author tomyjohn
 * @link
 * @license
 * @version 1.0
 * @copyright Copyright 2010 tomyjohn - tomyjohn.gicp.net
 * @package singleton
 */ 
/**
 * 数据库对象
 */ 
interface singleton{ 
     
    /**
     * 生成数据库对象
     * @returns object data object;
     * @access public 
     */ 
    public static function getInstance(); 

再新建一个抽象类,这个抽象类把所有的数据库都简明地用5个方法来抽象。
db.class.php
[php]
/**
 * @author tomyjohn
 * @link
 * @license
 * @version 1.0
 * @copyright Copyright 2010 tomyjohn - tomyjohn.gicp.net
 * @package db
 */ 
/**
 *抽象DB类
 */ 
abstract class db{ 
     
    /**
     * 工厂模式
     * @param string $type sql type 
     * @returns object 
     * @access public 
     */ 
    public static function factory($type){ 
        return call_user_func(array($type,'getInstance')); 
    } 
    /**
     * 执行SQL语句
     * @param string $query sql 语句
     * @return object resource or false;
     * @access public
     */ 
    abstract public function execute($query); 
    /**
     * 获取SQL语句返回的数组
     * @param string $query sql 语句
     * @return object resource or false;
     * @access public
     */ 
    abstract public function get_array($query); 
    /**
     * 获取上一条语句的执行ID
     * @param string $query sql 语句
     * @return integer number or false;
     * @access public
     */ 
    abstract public function insert_get_id($query); 
    /**
     * 转化特殊字符
     * @param string $string 
     * @return string 处理后的字符串
     * @access public
     */ 
    abstract public function clean($string); 

相信看到这里,都会想到那个call_user_func方法该如何使用,别急,往下看
mysql.class.php
[html]
/** 
 * @author tomyjohn 
 * @link 
 * @license 
 * @version 1.0 
 * @copyright Copyright 2010 tomyjohn - tomyjohn.gicp.net 
 * @package db 
 */ 
/** 
 *MYSQL数据库对象 
 */ 
class mysql extends db implements singleton{ 
     
    /** 
     * @var $instance object  
     * @access current class 
     */ 
    protected static $instance = null; 
    /** 
     * @var $link resource 
     * @access current class 
     */ 
    protected $link; 
     
    /** 
     * 数据库实例 
     * @return  $self::instance object 
     */ 
    public static function getInstance(){ 
        if(is_null(self::$instance)){ 
            self::$instance = new self(); 
        } 
        return self::$instance; 
    } 
     
    /** 
     * 构造器 
     */ 
    protected function __construct(){ 
        global $current_conf; 
        $user = $current_conf['DBUSER']; 
        $pass = $current_conf['DBPWD']; 
        $host = $current_conf['DBHOST']; 
        $db   = $current_conf['DBNAME']; 
         
        $this->link = mysql_connect($host,$user,$pass); 
         
        mysql_set_charset($current_conf['DBCHARSET'] , $this->link); 
        mysql_select_db($db); 
    } 
     
    /** 
     * 转化特殊字符 
     * @param string $string  
     * @return string 处理后的字符串 
     * @access public 
     */ 
    public function clean($string){ 
        return mysql_real_escape_string($string,$this->link); 
    } 
     
    /** 
     * 执行SQL语句 
     * @param string $query sql 语句 
     * @return object resource or false; 
     * @access public 
     */ 
    public function execute($query){ 
        return mysql_query($query,$this->link); 
    } 
    /** 
     * 获取上一条语句的执行ID 
     * @param string $query sql 语句 
     * @return integer number or false; 
     * @access public 
     */ 
    public function insert_get_id($query){ 
        $this->execute($query); 
        return mysql_insert_id($this->link); 
    } 
    /** 
     * 获取SQL语句返回的数组 
     * @param string $query sql 语句 
     * @return object resource or false; 
     * @access public 
     */ 
    public function get_array($query){ 
        $result = $this->execute($query); 
        $return = array(); 
        if($result){ 
            while($row = mysql_fetch_array($result , MYSQL_ASSOC)){ 
                $return[] =$row; 
            } 
        } 
        return $return; 
    } 

current_conf 这个数组是我项目里的,其实也可以用你数据库的用户名和密码代替,看完这个我想你们也应该清楚了,继承DB然后实现singleton接口后的这个类,其实也可用到MSSQL,ORACL,以及其他数据库,但是光有这个,我们只能使操作数据库变成这样

[html] view plaincopy
$connection = db::factory('mysql'); 
$sql = "SELECT * FROM table"; 
$value_array = $connection->get_array($sql); 
[html] view plaincopy
print_r($value_array); 
这样虽然解决了扩展,解决了一些重复的操作,但是还不是很方便,我们应该更进一步,使数据库表用对象表示,即数据库映射

dao.class.php

[html]
class dao{ 
    /** 
     * @var $values array 存放数据库对象  
     * @access current class 
     */ 
    protected $values = array(); 
     
    /** 
     * @var $suffix array 存放数据库对象  
     * @access public  
     */ 
    public $suffix = ''; 
     
    /** 
     * 构造器 
     */ 
    public function __construct($qualifier = null){ 
        global $current_conf; 
        $this->suffix = $current_conf['DBSUFFIX']; 
         
        if(!is_null($qualifier)){ 
            $conditional = array(); 
             
            if(is_numeric($qualifier)){ 
                $conditional = array('id'=>$qualifier); 
            } 
            else if(is_array($qualifier)){ 
                $conditional = $qualifier; 
            } 
            else{ 
                throw new Exception('Invalid type of qualifier given!'); 
            } 
             
            $this->populate($conditional); 
        }        
    } 
     
    public function __set($name , $value){ 
        $this->values[$name] = $value; 
    } 
     
    public function __get($name){ 
        if(isset($this->values[$name])){ 
            return $this->values[$name]; 
        } 
        else{ 
            return null; 
        } 
    } 
     
    /** 
     * 解析实例的参数  
     * @param $conditional obj  
     */ 
    protected function populate($conditional){ 
        $connection = db::factory('mysql'); 
         
        $sql = "SELECT * FROM {$this->suffix}{$this->table} WHERE "; 
        $qualifier = ''; 
         
        foreach($conditional as $column => $value){ 
            if(!empty($qualifier)){ 
                $qualifier .= ' AND '; 
            } 
            $qualifier .= "`{$column}`='" . $connection->clean($value) . "' "; 
        } 
         
        $sql .= $qualifier; 
        $value_array = $connection->get_array($sql); 
         
        if(!isset($value_array[0])){ 
            $value_array[0] = array(); 
        } 
         
        foreach($value_array[0] as $key => $value){ 
            $this->values[$key] = $value; 
        } 
    } 
     
    /** 
     * 保存数据 
     */ 
    public function save(){ 
        if(!$this->id){ 
            $this->create(); 
        } 
        else{ 
            return $this->update(); 
        } 
    } 
     
    /** 
     * 添加数据  www.2cto.com
     */ 
    public function create(){ 
        $connection = db::factory('mysql'); 
         
        $sql = "INSERT INTO {$this->suffix}{$this->table}(`"; 
        $sql .= implode('`, `' , array_keys($this->values)); 
        $sql .="`) VALUES('"; 
         
        $clean = array(); 
        foreach($this->values as $value){ 
            $clean[] = $connection->clean($value); 
        } 
         
        $sql .= implode("', '" , $clean); 
        $sql .="')"; 
         
        $this->id = $connection->insert_get_id($sql); 
    } 
     
    /** 
     * 更新数据 
     * @return 返回执行操作的结果 
     */ 
    public function update(){ 
        $connection = db::factory('mysql'); 
         
        $sql = "UPDATE {$this->suffix}{$this->table} set "; 
         
        $updates = array(); 
        foreach($this->values as $key=>$value){ 
            if($key!='id'){ 
                $updates[] = "`{$key}`='" . $connection->clean($value) . "'"; 
            } 
        } 
         
        $sql .= implode(',' , $updates); 
        $sql .= " WHERE id={$this->id}"; 
         
        return $connection->execute($sql); 
    } 
    /** 
     * 删除数据 
     * @return 返回执行操作的结果 
     */ 
    public function delete(){ 
        $connection = db::factory('mysql'); 
         
        $sql = "DELETE FROM {$this->suffix}{$this->table} WHERE "; 
        $qualifier = 'id='.$this->id; 
 
        $sql .= $qualifier; 
        return $connection->execute($sql); 
    } 
     
    /** 
     * 对象转成数组 
     * @return array 
     */ 
    public function object_to_array(){ 
        return $this->values; 
    } 
     

如果看到这里,我相信大家都会想去继承这个类。 是的,如果继承了这个类,那么每条记录就可以变成对象,就可以用面向对象的方式去处理了。

我写一个

news.dao.class


class news extends dao{ 
    protected $table = __CLASS__; 
     


作者:tomyjohn

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/478158.htmlTechArticle要用PHP操作一个数据库很简单,相应入门后的PHPER都可以做到,但是在应对大量的表操作时,我们为许多的MYSQL语句感到厌烦,所以我们急切...
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Apr 05, 2025 am 12:04 AM

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Expliquez l'expression de correspondance (PHP 8) et comment elle diffère du commutateur. Expliquez l'expression de correspondance (PHP 8) et comment elle diffère du commutateur. Apr 06, 2025 am 12:03 AM

Dans PHP8, les expressions de correspondance sont une nouvelle structure de contrôle qui renvoie différents résultats en fonction de la valeur de l'expression. 1) Il est similaire à une instruction Switch, mais renvoie une valeur au lieu d'un bloc d'instruction d'exécution. 2) L'expression de correspondance est strictement comparée (===), ce qui améliore la sécurité. 3) Il évite les éventuelles omissions de rupture dans les instructions de commutation et améliore la simplicité et la lisibilité du code.

Décrivez l'objectif et l'utilisation de l'opérateur ... (SPLAT) dans les arguments de fonction PHP et le déballage du tableau. Décrivez l'objectif et l'utilisation de l'opérateur ... (SPLAT) dans les arguments de fonction PHP et le déballage du tableau. Apr 06, 2025 am 12:07 AM

L'opérateur ... (SPLAT) dans PHP est utilisé pour déballer les paramètres et les tableaux de fonction, améliorant la simplicité et l'efficacité du code. 1) Démontage du paramètre de fonction: passez l'élément de tableau en tant que paramètre à la fonction. 2) Démontage du tableau: déballer un tableau dans un autre tableau ou en tant que paramètre de fonction.

Qu'est-ce que la contrefaçon de demande inter-sites (CSRF) et comment implémentez-vous la protection CSRF dans PHP? Qu'est-ce que la contrefaçon de demande inter-sites (CSRF) et comment implémentez-vous la protection CSRF dans PHP? Apr 07, 2025 am 12:02 AM

En PHP, vous pouvez prévenir efficacement les attaques du CSRF en utilisant des jetons imprévisibles. Les méthodes spécifiques comprennent: 1. Générer et intégrer les jetons CSRF dans la forme; 2. Vérifiez la validité du jeton lors du traitement de la demande.

Expliquez des types stricts (Declare (strict_types = 1);) en php. Expliquez des types stricts (Declare (strict_types = 1);) en php. Apr 07, 2025 am 12:05 AM

Les types stricts en PHP sont activés en ajoutant Declare (strict_types = 1); en haut du fichier. 1) Il force la vérification du type des paramètres de fonction et des valeurs de retour pour éviter la conversion de type implicite. 2) L'utilisation de types stricts peut améliorer la fiabilité et la prévisibilité du code, réduire les bogues et améliorer la maintenabilité et la lisibilité.

À quoi sert un compositeur? À quoi sert un compositeur? Apr 06, 2025 am 12:02 AM

Composer est un outil de gestion des dépendances pour PHP. Les étapes principales de l'utilisation du compositeur comprennent: 1) DÉCLARIER DES DÉPÉLENCES DANS COMPOSER.JSON, tels que "Stripe / Stripe-Php": "^ 7.0"; 2) Exécutez ComposeRrinstall pour télécharger et configurer les dépendances; 3) Gérer les versions et les autoloads via Composer.lock et Autoload.php. Le compositeur simplifie la gestion des dépendances et améliore l'efficacité du projet et la maintenabilité.

Mode sombre du bloc-notes: activer le mode sombre Mode sombre du bloc-notes: activer le mode sombre Apr 04, 2025 am 12:17 AM

Activer le mode sombre dans le bloc-notes nécessite de modifier les paramètres de registre. Les étapes spécifiques sont les suivantes: 1. Créez et enregistrez un fichier nommé darkmode.reg, avec le contenu défini par le registre. 2. Double-cliquez sur le fichier pour importer les paramètres, redémarrez le bloc-notes pour activer le mode sombre.

Quelle est la définition d'un compositeur? Quelle est la définition d'un compositeur? Apr 03, 2025 am 12:17 AM

Les compositeurs sont des gens qui fabriquent de la musique, expriment des émotions, racontent des histoires et transmettent des idées à travers la musique. Le travail du compositeur comprend: 1. Concept: Déterminer le thème et le style de l'œuvre; 2. Création: composer la mélodie et l'harmonie pour former une structure musicale préliminaire; 3. Expérience: Audition et ajustement des travaux via des instruments ou des logiciels; 4. Amélioration: modifiez et améliorez selon les résultats de l'audition jusqu'à ce que vous soyez satisfait.

See all articles