Codeigniter расширить базу данных - PullRequest
0 голосов
/ 19 октября 2011

Я использую этот пример для расширения драйвера CI mysql: http://codeigniter.com/wiki/Extending_Database_Drivers

И он работает очень хорошо, на самом деле у меня просто была странная проблема.Когда я пытаюсь загрузить другую конфигурационную базу данных, такую ​​как

$this->dbUsr = $CI->load->database(‘usuario’, TRUE);

Вот мой расширенный класс драйвера mysql, внутри него у меня есть функция с именем insertSelect, когда я использую

$this->db->insertSelect()

системунайти функцию и выполнить ее, но если я попытаюсь использовать $this->dbUsr->insertSelect(), система выдаст эту ошибку:

Fatal error: Call to undefined method CI_DB_mysql_driver::insertSelect()

Класс

<?php

class MY_DB_mysql_driver extends CI_DB_mysql_driver {

    public $CI;
    private $tabela;
    private $colunaai;
    private $where;

    function __construct($params) {
        parent::__construct($params);
        $this->CI =& get_instance();
        log_message('debug', 'Extended DB driver class instantiated!');
        echo 'MY_DB_mysql_driver<br/>';

    }



    /**
     * Função insere novos registros adicionando um contador a colunaai passada
     * nos parametros da funcao, deste modo é possível trabalhar com tabelas que
     * possuem chaves compostas.<br/>
     *
     * @param string $table
     * <p>A tabela o qual o método irá inserir um novo registro.</p>
     * @param array $data
     * <p>Array contendo todos dados que serão inseridos (Coluna de Auto-incremento tem que estar presente).</p>
     * @param string $colunaai
     * <p>Nome da coluna o qual o método irá incrementar o valor.</p>
     * @param array $where [Opcional]
     * <p>Array contendo os valores para a clausula que será montada(Usado somente em casos de chaves compostas).</p>
     * @return array resultado da query executada pelo método.
     * @access public
     */

    public function insertSelect($table, $data, $colunaai, $where = '') {
        $this->tabela = $table;
        $this->colunaai = $colunaai;
        $this->where = $where;

        $query = '';
        $driver = $this->CI->db->dbdriver;

        foreach ($data as $field => $value) {
            $fields[] = '`' . $field . '`';

            // Como parametro recebe a var colunaai, que no caso é a coluna do sistema de
            // autoincrement, caso a coluna seja igual a colunas o qual o array esta caminhando,
            // faz as validacoes para montar a clausula para autoincrement do campo
            if ($colunaai == $field) {

                // Valida o driver selecionado para montar o select de acordo com a sintaxe do SGBD selecionado
                // Monta o select para sintaxe do mysql
                if ($driver == 'mysql') {
                    $values[] = 'IfNULL(MAX(' . $colunaai . '),0) + 1';
                }

                // Monta o select para sintaxe do mssql server
                if ($driver == 'mssql') {
                    $values[] = 'ISNULL(MAX(' . $colunaai . '),0) + 1';
                }

                // Caso nao exista uma coluna definida para o autoincrement, ou caso ele n"ao seja encontrado no array
            } else {
                $values[] = "'" . mysql_real_escape_string($value) . "'";
            }
        }

        // Monta os valores separados por virgula
        $field_list = join(', ', $fields);
        $value_list = join(', ', $values);

        // Monta a estrutura do insert que sera executado
        $query = "
        INSERT INTO `" . $table . "` (" . $field_list . ")
        SELECT " . $value_list . "
        FROM `" . $table . "`";

        // Faz verificao para ver se existem valores para a clausula where
        if (!empty($where)) {

            $query .= 'WHERE ';
            $counter = 1;
            $sizearray = sizeof($where);

            // Percorre os elementos do array para adicionalos ao comando sql
            foreach ($where as $field => $value) {
                $query .= $field . ' = ' . $value;

                // Verifica quantos elementos existem no array, caso existam mais de uma acrescenta AND para a clausula
                if ($counter < $sizearray) {
                    $query .= ' AND ';
                }

                $counter++;
            }
        }

        // Volta para a classe o resultado do comnado sql executado
        return $this->CI->db->query($query);
    }

    public function lastInsert(){
        $colunaai = $this->colunaai;

        $this->CI->db->select($colunaai);
        $this->CI->db->order_by($colunaai, 'DESC');
        $query = $this->CI->db->get_where($this->tabela, $this->where);

        if ($query->num_rows > 0) {
            return $query->row()->$colunaai;
        }
    }

    public function errorHandling($number){

    }
}

?>  

1 Ответ

0 голосов
/ 19 октября 2011

Ваша фатальная ошибка показывает, что вы звоните CI_DB_MYSQL_Driver, а не MY_DB_mysql_driver

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...