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]   

> Описание: проблема с кодировкой
PixelPhoto
Отправлено: 08 Марта, 2010 - 19:46:08
Post Id


Новичок


Покинул форум
Сообщений всего: 8
Дата рег-ции: Март 2010  


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




Есть скрипт:
PHP:
скопировать код в буфер обмена
  1.  
  2. $dblocation = "localhost";
  3. $dbname = "base";
  4. $dbuser = "root";
  5. $dbpasswd = "1111";
  6. $dbcnx = @mysql_connect($dblocation,$dbuser,$dbpasswd);
  7.  
  8. if(!$dbcnx){ exit ("Base not work<br>"); }
  9. else{ echo("All right!<br>"); }
  10.  
  11. if(!@mysql_select_db($dbname,$dbcnx)){ exit ("<br>Base not connect<br>"); }
  12.  
  13.  $query = mysql_query("SET NAMES cp1251");
  14.  $query2 = mysql_query(" SELECT * FROM table1 LIMIT 0 , 30 ");
  15.  
  16.  while($row = mysql_fetch_object($query2)){ echo $row->name; }
  17.  
  18.  


Как видите ни где не происходит проверка правильности запросов-выхода из программы, однако, при удалении строчки с переменной $query за место русских символов я получаю "???? ??? ?????". Меня беспокоит вопрос, почему так происходит, ведь я нигде не использую данный запрос, можете убедиться в этом сами запустив данный скрипт. Спасибо.
 
 Top
A.N.R.I
Отправлено: 08 Марта, 2010 - 19:48:53
Post Id



Гость


Покинул форум
Сообщений всего: 122
Дата рег-ции: Март 2009  
Откуда: Вінницька обл.


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




Может потому что та строчка кодировку меняет!


-----
 
 Top
SAD Модератор
Отправлено: 08 Марта, 2010 - 19:49:18
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2508
Дата рег-ции: Май 2009  
Откуда: Днепропетровск, Украина


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




Все очень просто - этим запросом выставляется кодировка базы. Вот поэтому, когда Вы убираете строчку, выводятся ???????
 
 Top
PixelPhoto
Отправлено: 08 Марта, 2010 - 19:50:47
Post Id


Новичок


Покинул форум
Сообщений всего: 8
Дата рег-ции: Март 2010  


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




Спасибо, то что кодировку меняет это понятно, но я же только объявил переменную, но не использовал ее
 
 Top
SAD Модератор
Отправлено: 08 Марта, 2010 - 19:53:25
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2508
Дата рег-ции: Май 2009  
Откуда: Днепропетровск, Украина


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




Произошел запрос, необязательно использовать эту переменную. можете убрать $query = , оствавив только
CODE (SQL):
скопировать код в буфер обмена
  1. mysql_query("SET NAMES cp1251");
но все равно все будет в порядке
 
 Top
PixelPhoto
Отправлено: 08 Марта, 2010 - 19:55:05
Post Id


Новичок


Покинул форум
Сообщений всего: 8
Дата рег-ции: Март 2010  


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




Спасибо, понял, можно закрыть тему.
Тема закрыта!
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB