Проблема с классом mysqli

php MySQL ООП

Начал учить ООП в PHP5.
Создал такой класс для подключения к базе:

<?php

class db_conn extends mysqli {

var $db_host = 'localhost';
var $db_login = 'root';
var $db_pwd = '';
var $db_name = 'siga';

function cq($query) {
@ $this->db = new mysqli($this->db_host, $this->db_login, $this->db_pwd, $this->db_name);

if ($this->db->connect_errno) {
echo 'Ошибка: ' . $this->db->connect_error;
exit;
}

$this->result = $this->db->query($query);

$this->aff_rows = $this->db->affected_rows;
$this->num_rows = $this->result->num_rows;

}

}

?>

Выполняю:

include("mysql.php");

$db = new db_conn();
$db->cq("INSERT INTO registred VALUES('','$login','$pwd','$email')");

Все нормально.
Но если экранировать специальные символы входных данных:

$db = new db_conn();
$login = $db->real_escape_string($login);
$db->cq("INSERT INTO registred VALUES('','$login','$pwd','$email')");

То PHP выводит такую ошибку:

Warning: mysqli::real_escape_string() [mysqli.real-escape-string]: Couldn't fetch db_conn in /dee-lv.name/www/siga/register.php on line 66
Ответы:
Попробуй создать отдельный метод для этого действия.
Зачем в cq() каждый раз заново создавать подключение к серверу? Вообще весь класс следует переписать. Хотя бы перенести всё, что идёт до $this->result, в конструткор:
public function __construct()
{
 if (empty($this->db)) {
   $this->db = new mysqli(…);
   // обработка ошибок соединения…
 }
}


15 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.