Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Запись в БД из массива

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: Запись в БД из массива
dembi
Отправлено: 06 Ноября, 2009 - 12:13:35
Post Id


Новичок


Покинул форум
Сообщений всего: 55
Дата рег-ции: Апр. 2009  


Помог: 0 раз(а)




Привет всем!

У меня есть данные записанные, а одномерном массиве:

$ar = (‘Test1’,’Test2’…’Testn’)

Я хочу добавить эти данные в БД.

Пробую следующим образом:

CODE (text):
скопировать код в буфер обмена
  1.  
  2. foreach($ar as $val) {
  3.         echo $val."<br>";
  4.         $query = "INSERT INTO db.table1 (text) Values ('$val');";
  5.         mysql_query($query, $db);
  6. }
  7.  


Но почему-то записывается в БД только первая строчка.

Почему не записываются остальные данные?
Подскажите, в чем может быть дело.

Заранее спасибо.
 
 Top
Champion Супермодератор
Отправлено: 06 Ноября, 2009 - 12:22:55
Post Id



Активный участник


Покинул форум
Сообщений всего: 4350
Дата рег-ции: Авг. 2008  
Откуда: Москва


Помог: 57 раз(а)




echo mysql_error()
 
 Top
dembi
Отправлено: 06 Ноября, 2009 - 12:35:54
Post Id


Новичок


Покинул форум
Сообщений всего: 55
Дата рег-ции: Апр. 2009  


Помог: 0 раз(а)




Получаю вот такие ошибки:

Incorrect string value: '\xC4\xEE\xF1\xF2\xE0\xE2...' for column 'status_rus' at row 1Не доставлено
Incorrect string value: '\xCD\xE5 \xE4\xEE\xF1...' for column 'status_rus' at row 1Время истекло

и т.д.

А из-за чего, может возникать такая ошибка ?
 
 Top
Champion Супермодератор
Отправлено: 06 Ноября, 2009 - 12:49:56
Post Id



Активный участник


Покинул форум
Сообщений всего: 4350
Дата рег-ции: Авг. 2008  
Откуда: Москва


Помог: 57 раз(а)




Из-за кодировки. Какая в базе и какая там, откуда данные берутся?
 
 Top
dembi
Отправлено: 06 Ноября, 2009 - 12:54:53
Post Id


Новичок


Покинул форум
Сообщений всего: 55
Дата рег-ции: Апр. 2009  


Помог: 0 раз(а)




В БД используется UTF8.
Данные берутся из файла.

Как узнать, какая кодировка у меня для данных записанных в файл??
 
 Top
JustUserR
Отправлено: 06 Ноября, 2009 - 13:11:52
Post Id



Активный участник


Покинул форум
Сообщений всего: 8715
Дата рег-ции: Июнь 2009  


Помог: 17 раз(а)




dembi Наверное та же что и кодировка самого файла с данными (В вашем случае PHP-скрипта с массивом)
Учитывая что unicode это multibyte кодировка нужно конкертировать какимнибудь iconv (Может даже быть встроен в сборку PHP по умолчанию)


-----
Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик Улыбка
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
 
 Top
dembi
Отправлено: 06 Ноября, 2009 - 13:52:19
Post Id


Новичок


Покинул форум
Сообщений всего: 55
Дата рег-ции: Апр. 2009  


Помог: 0 раз(а)




Как я вижу, текст записан в кодировке «windows-1251», в БД мне нужно писать в кодировке UTF8

Пробую следующее:

CODE (text):
скопировать код в буфер обмена
  1.  
  2. foreach($ar as $val) {
  3.         iconv(“windows-1251”, “UTF8”, $val);
  4.         $query = "INSERT INTO sms.dr_status (status_rus) Values ('$val');";
  5.         mysql_query($query, $db);
  6.         echo mysql_error();
  7. }
  8.  


Все равно получаю туже ошибку.
 
 Top
Мелкий Супермодератор
Отправлено: 06 Ноября, 2009 - 14:07:12
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




iconv текст в новой кодировке возвращает, а не в переданную записывает, т.е.
$val = iconv(“windows-1251”, “UTF8”, $val);

И вообще, производительнее было бы отсылать всё одним куском:
PHP:
скопировать код в буфер обмена
  1.  
  2. $inf = '';
  3. foreach($ar as $val) {
  4.         $inf .= "('".iconv(“windows-1251”, “UTF8”, $val)."')";
  5. }
  6. $query = "INSERT INTO sms.dr_status (status_rus) Values ".str_replace(")(","),(",$inf);
  7. mysql_query($query, $db);
  8. echo mysql_error();
  9.  

(Отредактировано автором: 06 Ноября, 2009 - 14:08:04)



-----
PostgreSQL DBA
 
 Top
dembi
Отправлено: 06 Ноября, 2009 - 14:55:03
Post Id


Новичок


Покинул форум
Сообщений всего: 55
Дата рег-ции: Апр. 2009  


Помог: 0 раз(а)




Мелкий - спасибо Радость
 
 Top
JustUserR
Отправлено: 06 Ноября, 2009 - 16:46:08
Post Id



Активный участник


Покинул форум
Сообщений всего: 8715
Дата рег-ции: Июнь 2009  


Помог: 17 раз(а)




dembi Ну а в самой базе какая кодировка и вообще какая кодировка у установленного соединения?
Смотрите команду SET NAMES UTF-8


-----
Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик Улыбка
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Программирование на PHP »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB