Форум программистов, компьютерный форум, киберфорум
Наши страницы
PHP для начинающих
Войти
Регистрация
Восстановить пароль
 
botstars
2 / 3 / 2
Регистрация: 17.05.2013
Сообщений: 403
1

Функция работает, но выдает Notice: Array to string conversion

06.05.2017, 15:09. Просмотров 399. Ответов 2
Метки нет (Все метки)

Помогите исправить ошибку есть метод
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
public function insertMany($table, $object,$last = null,$count=null) {
            $columns = array();
            $i=1;
            foreach ($object as $value) {
                foreach ($value as $key=>$val) {
                    $masks[] = $val;
                    if($i==1) {
                        $columns[] = $key;
                    }
 
                    if ($value === null) {
                        $object[$key] = 'NULL';
                    }
                }
                $masks = implode("','", $masks);
                $masks2[]= "('".$masks."')";
                unset($masks);
                $i++;
            }
 
            $columns_s = implode('`,`', $columns);
 
            $masks_s = implode(',', $masks2);
            //echo $masks_s;
 
            $query = "INSERT INTO `$table` (`$columns_s`) VALUES $masks_s";
 
         
            $q = $this->db->prepare($query);
            $q->execute($object);
 
 
 
            if ($q->errorCode() != \PDO::ERR_NONE) {
                $info = $q->errorInfo();
                die($info[2]);
            }
 
            return $this->lastOrCount($last,$count,$i-1);
 
        }
ошибка в строке $q->execute($object); Notice Array to string conversion.
вот так я обращаюсь
PHP
1
 $last = $db->insertMany('parse', $array);
$array
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
Array
(
    [0] => Array
        (
            [plaсeParsing] => 27
            [fromGroup] => 120629957
            [status] => 0
            [idGroup] => 105632766
            [idPost] => 1354
            [datePublication] => 2017-05-05 12:01:10
        )
 
    [1] => Array
        (
            [plaсeParsing] => 27
            [fromGroup] => 120629957
            [status] => 0
            [idGroup] => 141817217
            [idPost] => 34
            [datePublication] => 2017-05-04 17:58:53
        )
 
)
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.05.2017, 15:09
Ответы с готовыми решениями:

Notice: Array to string conversion in
<?php $keys = array_keys($_POST); foreach($keys as $key) { echo ($key); echo ' : ' ; echo...

Notice: Array to string conversion
<?php $arrayVar = ; echo '$arrayVar = ' . $arrayVar; //line 10 ?> Выдает

Ошибка PHP Notice: Array to string conversion in
День добрый. Подскажите начинающим в PHP Постоянно выдается ошибка - ну вроде как и не ошибка а...

Notice: Array to string conversion in /home/komp/www/site1.my/www/index.php on line 58 Array
Notice: Array to string conversion in /home/komp/www/site1.my/www/index.php on line 58 Array ...

Notice: Array to string conversion in C:Program FilesPHP Expert EditorphpB8.tmp on line 7
пример взял из руководства тока подставил сой адрес в ответ <?php ...

2
Jewbacabra
Эксперт PHP
3919 / 3227 / 1401
Регистрация: 24.04.2014
Сообщений: 9,788
06.05.2017, 15:52 2
Цитата Сообщение от botstars Посмотреть сообщение
ошибка в строке $q->execute($object);
А зачем передавать параметр в метод execute, ты же не используешь плейсхолдеры в запросе? И prepare нет смысла в таком случае использовать, можно сразу выполнять с помощью query
0
botstars
2 / 3 / 2
Регистрация: 17.05.2013
Сообщений: 403
06.05.2017, 17:31  [ТС] 3
Jewbacabra, это не мое подсмотрено на просторах интернета , буду разбираться

Добавлено через 1 час 6 минут
Jewbacabra, посмотрите пожалуйста не знаю вроде ошибка пропала но я там всего скорее неправильно сделал вот весь класс который у меня есть по бд я просто закомментировал что удалил в методе insertMany
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
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
  class sql{
        private static $instance;
        private $db;
 
        public static function app() {
            if (self::$instance == null) {
                self::$instance = new self();
            }
 
            return self::$instance;
        }
 
        private function __construct() {
            setlocale(LC_ALL, 'ru_RU.UTF8');
            $this->db = new \PDO('mysql:host=' . MYSQL_SERVER . ';dbname=' . MYSQL_DB, MYSQL_USER, MYSQL_PASSWORD);
            $this->db->exec('SET NAMES UTF8');
            $this->db->setAttribute(\PDO::ATTR_DEFAULT_FETCH_MODE, \PDO::FETCH_ASSOC);
        }
 
        public function select($query, $params = array()) {
 
          $q = $this->db->prepare($query);
            $q->execute($params);
 
            if ($q->errorCode() != \PDO::ERR_NONE) {
                $info = $q->errorInfo();
                die($info[2]);
            }
 
            return $q->fetchAll();
        }
        
        public function getByHash($table, $hash_key, $hash_value, $real_key, $real_value){
            $q = $this->db->prepare("SELECT * FROM $table WHERE $hash_key=:$hash_key");
            $q->execute(array($hash_key => $hash_value));
        
 
            if ($q->errorCode() != \PDO::ERR_NONE) {
                $info = $q->errorInfo();
                die($info[2]);
            }
 
            while($row = $q->fetch()){
                if($row[$real_key] == $real_value)
                    return $row;
            }
            
            return null;
        }
 
        public function insert($table, $object, $last=null) {
            $columns = array();
 
            foreach ($object as $key => $value) {
 
                $columns[] = $key;
                $masks[] = $value;
 
                if ($value === null) {
                    $object[$key] = 'NULL';
                }
            }
 
            $columns_s = implode(',', $columns);
            $masks_s = "'".implode('\',\'', $masks)."'";
 
            $query = "INSERT INTO $table ($columns_s) VALUES ($masks_s)";
 
 
 
            $q = $this->db->prepare($query);
            $q->execute($object);
 
            if ($q->errorCode() != \PDO::ERR_NONE) {
                $info = $q->errorInfo();
                die($info[2]);
            }
 
            if($last == true ) {
                return $this->lastInsertId();
            }
            else{
                return null ;
            }
        }
        public function lastInsertId(){
            $resalt = $this->select("SELECT LAST_INSERT_ID()");
 
            if(isset($resalt[0]['LAST_INSERT_ID()'])){
                $resalt = $resalt[0]['LAST_INSERT_ID()'];
            }
            return $resalt;
        }
        public function insertMany($table, $object,$last = null,$count=null) {
            $columns = array();
            $i=1;
            foreach ($object as $value) {
                foreach ($value as $key=>$val) {
                    $masks[] = $val;
                    if($i==1) {
                        $columns[] = $key;
                    }
 
                    if ($value === null) {
                        $object[$key] = 'NULL';
                    }
                }
                $masks = implode("','", $masks);
                $masks2[]= "('".$masks."')";
                unset($masks);
                $i++;
            }
 
            $columns_s = implode('`,`', $columns);
 
            $masks_s = implode(',', $masks2);
            //echo $masks_s;
 
            $query = "INSERT INTO `$table` (`$columns_s`) VALUES $masks_s";
 
            $this->select($query);
            //$q = $this->db->prepare($query);
            //$q->execute($object);
 
            //if ($q->errorCode() != \PDO::ERR_NONE) {
                //$info = $q->errorInfo();
                //die($info[2]);
            //}
 
            return $this->lastOrCount($last,$count,$i-1);
 
        }
        public function lastOrCount ($last=null,$count=null,$i=null){
 
            if ($count == true and $last == true ){
 
                return $array = array($this->lastInsertId(),$i);
 
            } else if($last == true){
 
                return $this->lastInsertId();
            }
            if($count == true ) {
 
                return $i;
            }
            else{
                return null ;
            }
        }
        
        public function update($table, $object, $where, $params = array()) {
            $sets = array();
 
            foreach ($object as $key => $value) {
 
                $sets[] = "$key=:$key";
 
                if ($value === NULL) {
                    $object[$key] = 'NULL';
                }
            }
 
            $sets_s = implode(',', $sets);
            $query = "UPDATE $table SET $sets_s WHERE $where";
            ///echo $query;exit();
            $q = $this->db->prepare($query);
            $q->execute(array_merge($object, $params));
 
            if ($q->errorCode() != \PDO::ERR_NONE) {
                $info = $q->errorInfo();
                die($info[2]);
            }
 
            return $q->rowCount();
        }
 
        public function delete($table, $where, $params = array()) {
            $query = "DELETE FROM $table WHERE $where";
            $q = $this->db->prepare($query);
            $q->execute($params);
 
            if ($q->errorCode() != \PDO::ERR_NONE) {
                $info = $q->errorInfo();
                die($info[2]);
            }
 
            return $q->rowCount();
        }
 
 
    }
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.05.2017, 17:31

Интересный notice: "Array to string conversion". Как?
Подскажите, господа, как в такой строке $a = array_merge(array_diff($a, $var1), $var2); ...

Ошибка "Array to string conversion in"
объясните в чем тут ошибка? echo "<form method='post'>"; foreach ($_POST as $k=>$v){ if...

Notice: array to string conversion
Здравствуйте, помогите разобраться с кодом mediawiki: дело в том, что я пытаюсь прикрутить к...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru