Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
24 / 20 / 3
Регистрация: 29.11.2012
Сообщений: 454
Записей в блоге: 1

не может принять аргументы

08.06.2013, 19:06. Показов 1021. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня такая проблема выдает такую ошибку Fatal error: Destructor DataBase::__destruct() cannot take arguments in C:\xampp\htdocs\site.local\dvich\lib\dat abase_class.php on line 151

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
<?php
    require_once "config_class.php";
    require_once "checkvalid_class.php";
 
class DataBase {
        private $config;
        private $mysqli;
        private $valid;
 
        public function _construct() {
            $this->config = new Config();
            $this->valid = new CheckValid();
            $this->mysqli = new mysqli($htis->config->host, $this->config->user, $this->config->password, $this->config->db);
            $this->mysqli->query("SET NAMES 'utf8'");
            }
        private function query($query) {
            return $this-> mysqli-> query($query);
            }
 
            /*метод который занимается выборкой*/
        private function select($table_name, $fields, $where = "", $order = "", $up = true, $limit = "") {
            for ($i = 0; $i < cout ($fields); $i++) {
                if ((strpos($fields[$i], "(") ===false) && ($fields[$i] != "*")) $fields[$i] = "`".$fields[$i]."`";
                }
            $fields = implode(",",$fields);     /*ФУНКЦИЯ КОТОРАЯ ПРЕВРАЩАЕТ МАССИВ В СТРОКУ*/
            $table_name = $htis->config->db_prefix.$table_name;
            if (!$order) $order = "ORDER BY `id`";      /*если ордер не задан создает сами и формируем по id */
            else{
                if ($order != "RAND()"){
                    $order = "ORDER BY `$order` ";
                    if (!up) $order .=" DESC";
                    }
                else $order = "ORDER BY $order";
                }
                if ($limit) $limit = "LIMIT $limit";
                if ($where) $query = "SELECT $fields FROM $table_name WHERE $where $order $limit";
                else $query = "SELECT $fields FROM $table_name $order $limit";
                $result_set = $htis->query($query);
                if (!$result_set) return false;
            /*прелбразовываем запрос в двумерный массив*/
                $i = 0;
                while ($row = $result_set->fetch_assoc()) {
                    $data[$i] = $row;
                    $i++;
                    }
                $result_set->close();
                return $data;
            }
            /*функция добавления записи*/
            public function insert ($table_name, $new_values) {
                $table_name = $this->config->db_prefix.$table_name;
                $query = "INSERT INTO $table_name (";
                foreach ($new_values as $field => $value) $query .= "`". $field."`,";
                $query = substr($query, 0, -1);                 /* убирает знак -1,запетая которпая указывается в строке выше*/
                $query .= ") VALUES (";
                foreach ($new_values as $value) $query .= "'".addslashes(values)."',";
                $query = substr($query, 0, -1);
                $query .= ")";
                return $this->query($query);
                }
            /*функция для обновления даных*/
            private function update($table_name, $update, $where) {
                $table_name = $this->config->db_prefix.$table_name;
                $query = "UPDATE $table_name SET";
                foreach ($upd_fields as $field => $value) $query .= "`$field` = '".addslashes(values)."',";
                $query = substr($query, 0, -1);
                if ($where) {
                    $query .=" WHERE $where";
                    return $this->query($query);
                    }
                    else return false;
                }
            /*удаление данных*/
            public function delete($table_name, $where= "") {
                $table_name = $this->config->db_prefix.$table_name;
                    if ($where) {
                        $query= "DELETE FROM $table_name WHERE $where";
                        return $this->query($query);
                        }
                    else return false;
                }
            /*очистка таблиц*/
            public function deleteAll($table_name) {
                $table_name = $this->config->db_prefix.$table_name;
                $query = "TRUNCATE TABLE `$table_name`";
                return $this->query($query);
                }
            public function getField($table_name, $field_out, $field_in, $value_in) {
                $data = $this->select($table_name, array($field_out), "`$field_in`='".addslashes($value_in)."'");
                if (count($data) != 1) return false;
                return $data[0][$field_out];
                }
            public function getFieldOnID($table_name, $id, $field_out) {
                if (!$this->existsID($table_name, $id)) return false;
                return $this->getField($table_name, $field_out, "id", $id);
                }
            /*получение всех записей из таблици*/
            public function getAll($table_name, $order, $up) {
                return $this->select($table_name, array("*"), "", $order, $up);
                }
            public function getAllOnField($table_name,$field,$value, $order, $up) {
                return $this->select($table_name, array("*"), "`$field`='".addslashes($value)."'", $order, $up);
                }
            public function getLastID($table_name) {
                $data = $this->select($table_name, array("MAX(`id`)"));
                return $data[0] ["MAX(`id`)"];
                }
            
            public function deleteOnID($table_name, $id) {
                if (!$htis->existsID($table_name, $id)) return false;
                return $this->delete($table_name, "`id` = '$id'");
                }
                
            public function setField($table_name, $field, $value, $field_in, $value) {
                return $this->update($table_name, array($field=> $value), "`field_in` = '".addslashes($value_in)."'");
                }
            public function setFieldOnID($table_name, $id, $field, $value) {
                if (!$htis->existsID($table_name, $id)) return false;
                return $this->setField($table_name, $field, $value, "id", $id );
                }
            /*возвращает всю запись целяком*/
            public function getElementOnID($table_name, $id) {
                if (!$htis->existsID($table_name, $id)) return false;
                $arr = $this->select($table_name,array("*"), "`id` = 'id'");
                return $arr[0];
                }
        
            public function getRandomElements($table_name, $count) {
                return $this->select($table_name, array("*"), "", "RAND()", true, $count);
                }
 
            public function getCount($table_name) {
                $data = $this->select($table_name, array("COUNT(`id`)"));
                return $data[0]["COUNT(`id`)"];
                }
        
            public function isExists ($table_name, $field, $value) {
                $data = $this->select($table_name, array("id"), "`$field` ='".addslashes($value)."'");
                if (count($data) === 0) return false;
                return true;
                }
            public function existsID ($table_name, $id) {
                if (!$this-> valid->validID($id)) return false;
                $data= $this->select($table_name,array("id"), "`id` ='".addslashes($id)."'");
                if (count($data) ===0) return false;
                return true;
                }
            public function __destruct($table_name, $field, $value) {
                if ($this->mysqli) $this->mysqli->close();
                }/*151*/
    }
 
?>
В чем проблема? Спасибо кто посмотрит!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.06.2013, 19:06
Ответы с готовыми решениями:

Переменная не может принять размер int64
Рабочий код на D: import std.stdio; void main() { byte h; long n, ans = 0; readf(&quot; %s %s&quot;, &amp;h, &amp;n); ...

Слушающий сокет не может принять соединение
#include &lt;iostream&gt; #include &lt;winsock2.h&gt; void WSAmel(){ WSADATA w; if (WSAStartup(0x202,&amp;w)){ std::cout &lt;&lt; &quot;Error WSA...

Batch-файл может принимать аргументы запуска
Batch-файл может принимать аргументы запуска. Чтобы запустить Batch-файл с аргументами: 1) откройте консоль: Win + R, вводим CMD,...

4
 Аватар для Dolphin
814 / 797 / 201
Регистрация: 21.09.2012
Сообщений: 2,656
08.06.2013, 19:25
Цитата Сообщение от Serezha Посмотреть сообщение
PHP
1
public function __destruct($table_name, $field, $value) { if ($this->mysqli) $this->mysqli->close(); }
Цитата Сообщение от Serezha Посмотреть сообщение
__destruct() cannot take argumen
Деструктор не может принимать входные параметры
0
24 / 20 / 3
Регистрация: 29.11.2012
Сообщений: 454
Записей в блоге: 1
08.06.2013, 19:39  [ТС]
Дак вот почему он не может принять??
0
 Аватар для Dolphin
814 / 797 / 201
Регистрация: 21.09.2012
Сообщений: 2,656
08.06.2013, 19:43
Потому что он по идее ничего не может принять
0
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
09.06.2013, 07:39
Цитата Сообщение от Serezha Посмотреть сообщение
Дак вот почему он не может принять??
Потому что их ему никто никогда не передаст.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.06.2013, 07:39
Помогаю со студенческими работами здесь

Определить длину строки которую может принять wcf сервис
Здравствуйте форумчане. Подскажите новичку как определить максимальную длину строки которую может принять и передать wcf сервис ? ...

какой объём картинки (MMS) может принять NOKIA 5300?
Человек в деревне живёт, надо скинуть ему картинку на сотовый, а он не знает такой характеристики, ни инструкции ни хрена нет к телефону. И...

Ящик не может принять наследство по классам (размеры, вес и цвет)
Здравствуйте! Детская задача, но что-то не стыкуется. Не могу сообразить: чего не хватает ящику, почему PyScripter не признаёт код? ...

Установить, может ли принять потерпевших на борт без изменений маршрута судно
Для организации поисков терпящей кораблекрушение шхуны необходимо срочно установить: может ли принять потерпевших на борт без изменений...

Переменной а присвоить максимальное значение, которое она может принять без переполнения
Всем привет. Нужна помощь, однако. Значит, сижу я за незнакомым компьютером в неизвестном городе, в неизвестной стране и...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение Это мой обзор планшета X220 с точки зрения школьника. Недавно я решила попытаться уменьшить свой. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru