Inhaltsverzeichnis
2. [文件] DbTool.class.php
Heim php教程 PHP源码 封装的 mysql类, 和sql语句生成类

封装的 mysql类, 和sql语句生成类

May 26, 2016 am 08:20 AM

host = $server['host'];
            $this->user = $server['user'];
            $this->pwd  = $server['pwd'];
            $this->port = $server['port'];
            $this->dbname = $server['dbname'];            
            
            $this->connect();
            
        }//End of function       


        public static function  getInstance($server)
        {
            if(  self::$isConnect  ) {
                return self::$handle;    
             }  

            self::$handle =  new self($server);        
            self::$isConnect = true;

            return self::$handle;
        }//End of funtion


        private function connect()
        {
            $this->resource = mysql_connect($this->host.':'.$this->port,
                                             $this->user,
                                             $this->pwd
                             ) or $this->error("connect fail");
            
            mysql_select_db($this->dbname, $this->resource);
            
            return true;
        }
        
        
        private function getSql($sql)
        {
            $operate = array('insert', 'delete', 'update', 'select', 'create');
            return $sql;
        }
        
        
        public function query($sql)
        {
            $sql = $this->getSql($sql);
            mysql_query("SET NAMES UTF8");
            $query_result = mysql_query($sql, $this->resource) or $this->error("query fail");
            
            return $query_result;
        }


        public function getQueryResult($sql)
        {
            $query_result = $this->query($sql);

            $result = array();
            if( !$query_result ) {
                return $result;
            }

            while ( $row = mysql_fetch_assoc($query_result) ) {
                $result[] = $row;
            }
            $result['rows'] = mysql_num_rows($query_result);
            $query_result = null;
 
            return $result;
        }        

        
        public function getInsertResult($sql)
        {
            $query_result = $this->query($sql);
                       
            if( !$query_result  ) {
                return false;
            }

            return mysql_insert_id($this->resource);
        }            

        
        public function getUpdateResult($sql)
        {
            
            $query_result = $this->query($sql);
            
            if( !$query_result ) {
                return false;
            }
            
            return mysql_affected_rows($this->resource);
        }


        public function getDeleteResult($sql)
        {
            return $this->getUpdateResult($sql);    
        }        

        
        public function close_connect()
        {
            self::$handle = null;
            self::$isConnect = false;
            mysql_free_result($this->resource);
            $this->resource = null;
        }        

        
        private function error($msg='')
        {
           $msg = "$msg--->>".mysql_error();
           die($msg);
        }

}//End of class    


?>
Nach dem Login kopieren

2. [文件] DbTool.class.php

primary_key = $primary_key;
           }
        }
        
        public function getInsertSql($data, $table) {
            $sql = $key_str = $value_str = "";
            foreach($data as $key=>$value) {
                $key_str .= "{$key}, ";
                $value_str .= "'{$value}', ";
            }
            $key_str = trim($key_str, ', ');
            $value_str = trim($value_str, ', ');
            $sql = "INSERT INTO {$table}({$key_str}) VALUES({$value_str})";
            $data=null; $key_str=null; $value_str=null;
            
            return $sql;
        }


        public function getUpdateSql($data, $table) {
            $pk = $this->primary_key;
            $id = $data[$pk]; unset($data[$pk]);
            $sql = $key_value = "";
            foreach($data as $key=>$value) {
                $key_value .= "{$key}='{$value}', ";
            }
            $key_value = trim($key_value, ', ');
            $sql = "UPDATE {$table} SET {$key_value} WHERE $pk='{$id}'";
            $data=null; $key_value=null;

            return $sql;
        }


        public function getQuerySql($condition, $table) {
            $field = empty($condition['field']) ? '*': $condition['field'];
            $sql = "SELECT {$field} FROM {$table}  ";
            if( isset($condition['where']) ) {
                $sql .= "WHERE {$condition['where']} ";
            }
            if( isset($condition['groupby']) ) {
                $sql .= "GROUP BY {$condition['groupby']} ";
            }
            if( isset($condition['orderby']) ) {
                $sql .= "ORDER BY {$condition['orderby']} ";
            }
            if( isset($condition['limit']) ) {
                $sql .= "LIMIT {$condition['limit']} ";
            }
            $condition=null;

            return $sql;
        }



        public function getDeleteSql($id, $table) {
   
            $pk = $this->primary_key; 
            $sql = "DELETE FROM {$table} WHERE $pk='{$id}' ";
            return $sql;
        }

    }


?>
Nach dem Login kopieren

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)