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]   

> Без описания
ATOM
Отправлено: 14 Декабря, 2011 - 22:49:22
Post Id


Гость


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


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




Товарищи помогите осуществить ротатор баннеров с помощью mysql.
вот что сделал на php как можно сделать тоже самое только из таблицы banner пусть сортировка будет по id:
структура таблицы ID и сам баннер пример:
id:banner
1:http://site[dot]ru/1[dot]gif
2:http://site[dot]ru/2[dot]gif
3:http://site[dot]ru/3[dot]gif
и суть что бы выводилось рандомно при каждом обновлении страницы.
вот что сделал на php:
PHP:
скопировать код в буфер обмена
  1.  
  2. <?
  3. $ban1="<img src='http://ifors.net/banner.gif'>";
  4. $ban2="<img src='http://forexpartnerkurs.ru/files/forexcash.gif'>";
  5. $banner=rand(1,2);
  6. if ($banner=='1'){$banner=$ban1;}
  7. if ($banner=='2'){$banner=$ban2;}
  8. echo $banner;
  9. ?>
  10.  
 
 Top
Panoptik
Отправлено: 14 Декабря, 2011 - 23:16:45
Post Id



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


Покинул форум
Сообщений всего: 2493
Дата рег-ции: Нояб. 2011  
Откуда: Одесса, Украина


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




здесь вам нужно не mysql мучать а использовать обыкновенный js -ротатор с функцией рандом посмотрите в гугле полно такого добра


-----
Just do it
 
 Top
ATOM
Отправлено: 14 Декабря, 2011 - 23:32:07
Post Id


Гость


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


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




js не надо надо именно вывод с помощью mysql
 
 Top
Panoptik
Отправлено: 14 Декабря, 2011 - 23:34:40
Post Id



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


Покинул форум
Сообщений всего: 2493
Дата рег-ции: Нояб. 2011  
Откуда: Одесса, Украина


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




в помощь


-----
Just do it
 
 Top
etoYA
Отправлено: 15 Декабря, 2011 - 02:20:38
Post Id



Участник


Покинул форум
Сообщений всего: 1859
Дата рег-ции: Июль 2011  
Откуда: Крым


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




PHP:
скопировать код в буфер обмена
  1. <?
  2. $result = mysql_query("SELECT `колонка с картинками` FROM `таблица`");
  3. while ($row = mysql_fetch_array($result)) {
  4.     $array[] = $row['img'];
  5. }
  6. $rand = array_rand($array, 1);
  7. echo '<img src="'.$array[$rand].'" />';
  8. ?>

(Отредактировано автором: 15 Декабря, 2011 - 02:20:48)

 
 Top
DeepVarvar Супермодератор
Отправлено: 15 Декабря, 2011 - 12:03:34
Post Id



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


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


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




etoYA - гон.
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT `колонка с картинками` FROM `таблица` ORDER BY RAND() LIMIT 1
 
 Top
etoYA
Отправлено: 16 Декабря, 2011 - 00:59:51
Post Id



Участник


Покинул форум
Сообщений всего: 1859
Дата рег-ции: Июль 2011  
Откуда: Крым


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




DeepVarvar, незнал)
 
 Top
tuareg
Отправлено: 16 Декабря, 2011 - 02:28:48
Post Id


Участник


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


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




DeepVarvar пишет:

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT `колонка с картинками` FROM `таблица` ORDER BY RAND() LIMIT 1

Это применимо, если не много баннеров. На большой таблице это плохо. Можно же закэшировать массив с баннерами в файл/сессию и оттуда их брать
 
 Top
EuGen Администратор
Отправлено: 16 Декабря, 2011 - 09:02:56
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




DeepVarvar пишет:
SELECT `колонка с картинками` FROM `таблица` ORDER BY RAND() LIMIT 1


- плохо, если таблица большая (большое число строк), так как значение вычисляется каждый раз.

Я, к примеру, в таких случаях (когда таблица большая) делаю в два запроса:

CODE (sql):
скопировать код в буфер обмена
  1. SELECT COUNT(1) FROM `table`;


- получаю некоторое значение, обозначим его $iRecordsCount. Обозначим число случайных строк, которое требуется выбрать, как $iRecordsNeeded. Тогда нужный результат даст следующий запрос:

CODE (sql):
скопировать код в буфер обмена
  1. SELECT * FROM `table` WHERE RAND()<=$iRecordsNeeded/$iRecordsCount LIMIT $iRecordsNeeded


Этот способ, однако, не должен применяться, когда таблица мала, либо когда число выбираемых строк сопоставимо с размером таблицы. Например, если таблица имеет несколько миллионов строк и выбрать нужно порядка 100-1000 случайных, способ подойдет. Но если в таблице всего 100 строк, выбрать при этом нужно 10 - то нет. Связано это с тем, что RAND() в случае малых таблиц вернет неравномерно распределенную последовательность значений. Чем больше число строк - тем более равномерно будут распределены значения. Это же относится и к случаю, когда число выбираемых строк соизмеримо с общим размером таблицы.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Напишите за меня, пожалуйста »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB