Расширение класса MySQLi - PullRequest
       8

Расширение класса MySQLi

2 голосов
/ 30 ноября 2009

Я хочу иметь возможность создавать классы, расширяющие класс MySQLi для выполнения всех его SQL-запросов.

$mysql = new mysqli('localhost', 'root', 'password', 'database') or die('error connecting to the database');

Я не знаю, как это сделать без глобализации объекта $ mysql для использования в моих других методах или классах.

class Blog {

public function comment() {
    global $mysql;

    //rest here
}

}

Любая помощь будет оценена.

Спасибо.

Ответы [ 5 ]

12 голосов
/ 15 января 2010

Я работал над чем-то похожим. Я рад этому единственному классу, который инкапсулирует логин базы данных.

<?php
class db extends mysqli
{
    protected static $instance;
    protected static $options = array();

    private function __construct() {
        $o = self::$options;

        // turn of error reporting
        mysqli_report(MYSQLI_REPORT_OFF);

        // connect to database
        @parent::__construct(isset($o['host'])   ? $o['host']   : 'localhost',
                             isset($o['user'])   ? $o['user']   : 'root',
                             isset($o['pass'])   ? $o['pass']   : '',
                             isset($o['dbname']) ? $o['dbname'] : 'world',
                             isset($o['port'])   ? $o['port']   : 3306,
                             isset($o['sock'])   ? $o['sock']   : false );

        // check if a connection established
        if( mysqli_connect_errno() ) {
            throw new exception(mysqli_connect_error(), mysqli_connect_errno()); 
        }
    }

    public static function getInstance() {
        if( !self::$instance ) {
            self::$instance = new self(); 
        }
        return self::$instance;
    }

    public static function setOptions( array $opt ) {
        self::$options = array_merge(self::$options, $opt);
    }

    public function query($query) {
        if( !$this->real_query($query) ) {
            throw new exception( $this->error, $this->errno );
        }

        $result = new mysqli_result($this);
        return $result;
    }

    public function prepare($query) {
        $stmt = new mysqli_stmt($this, $query);
        return $stmt;
    }    
}

Для использования вы можете иметь что-то вроде этого:

<?php
require "db.class.php";

$sql = db::getInstance();

$result = $sql->query("select * from city");

/* Fetch the results of the query */ 
while( $row = $result->fetch_assoc() ){ 
    printf("%s (%s)\n", $row['Name'], $row['Population']); 
} 
?>
3 голосов
/ 30 ноября 2009

Я предлагаю создать класс Singleton DataAccess, создать экземпляр этого класса в глобальном конфигурационном файле и вызвать его в своем классе блога, как $query = DataAccess::query("SELECT * FROM blog WHERE id = ".$id).

Посмотрите на шаблон Singleton, его довольно легко понять с помощью designpattern. Идеально подходит для этой ситуации.

Ваш класс DataAccess может иметь несколько методов, таких как query, fetchAssoc, numRows, checkUniqueValue, transactionStart, transactionCommit, transactionRollback и т. Д. И т. Д. Эти функции также можно настроить как интерфейс который реализуется классом DataAccess. Таким образом, вы можете легко расширить свой класс DataAccess для нескольких систем управления базами данных.

Вышесказанное в значительной степени описывает мою модель DataAccess.

1 голос
/ 30 ноября 2009

Вы можете использовать ключевое слово extends PHP просто для любого другого класса:

class MyCustomSql extends mysqli {

    public function __construct($host, $user, $password, $database) {
        parent::__construct($host, $user, $password, $database);
    }

    public function someOtherMethod() {
    }
}

$sql = new MyCustomSql('localhost', 'root', 'password', 'database') or die('Cannot connect!');

или лучше использовать агрегацию объектов вместо наследования:

class MySqlManipulator {

    private $db;

    public function __construct($host, $user, $password, $database) {
        $this->db   = new mysqli($host, $user, $password, $database);
    }

    public function someOtherMethod() {
        return $this->db->query("SELECT * FROM blah_blah");
    }
}

$mysqlmanipulator = new MySqlManipulator('localhost', 'root', 'password', 'database') or die('Cannot connect!');
0 голосов
/ 30 ноября 2009

Взгляните на PDO , который выдает исключения, которые вы можете отследить в случае сбоя запроса. Он широко используется и протестирован, поэтому у вас не должно возникнуть проблем с поиском существующих решений во время его использования.

Чтобы добавить его в класс блога:

class Blog {

    private $_db;

    public function __construct(PDO $db) {
        $this->_db = $db
    }

    public function comment() {
        return $this->_db->query(/*something*/);
    }

}
0 голосов
/ 30 ноября 2009

Мой стандартный метод - создать класс singleton , который действует как средство доступа к базе данных, и базовый класс, от которого наследуется все, требующее такого доступа.

Итак:

class Base {

  protected $db;

  function __construct(){
    $this->db= MyDBSingleton::get_link();
    //any other "global" vars you might want 
  }

}


class myClass extends Base {

  function __construct($var) {
     parent::__construct();// runs Base constructor
     $this->init($var);
  }

  function init($id) {
    $id=(int) $id;
    $this->db->query("SELECT * FROM mytable WHERE id=$id");
    //etc.
  }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...