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]   

> Описание: ПХП МуСКЛ
dmn
Отправлено: 14 Мая, 2008 - 23:56:29
Post Id



Новичок


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


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




Помогите пожалуйста!!! Есть одна БД, в ней много вопросов на несколько тем (к примеру три темы), нужно чтоб на одну страницу выводило три вопроса по первой теме, два - по второй и один - по первой! и записывало кол-во правильных ответов в переменную!!!

id | tema | vopros | variantotvetov | otvet

(Отредактировано автором: 14 Мая, 2008 - 23:57:30)

 
 Top
EuGen Администратор
Отправлено: 15 Мая, 2008 - 09:31:10
Post Id


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


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


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




Хм, а в чем трудности? .. Запросы такие:
CODE (text):
скопировать код в буфер обмена
  1.  
  2. SELECT * FROM questions WHERE tema=3 ORDER BY RAND() LIMIT 3;
  3. SELECT * FROM questions WHERE tema=2 ORDER BY RAND() LIMIT 2;
  4. SELECT * FROM questions WHERE tema=1 ORDER BY RAND() LIMIT 1;
  5.  

Проверку правильности в соответствии с Вашей схемой можно сделать, сопоставляя пришедшие ответы с полем otvet.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
dmn
Отправлено: 15 Мая, 2008 - 20:21:03
Post Id



Новичок


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


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




$query = "SELECT * FROM questions where tema=1 ORDER BY RAND() LIMIT 3"

а как тут три запроса написать?
 
 Top
EuGen Администратор
Отправлено: 15 Мая, 2008 - 20:55:52
Post Id


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


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


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




Если Вам все нужно в одном запросе, то можете использовать:
CODE (text):
скопировать код в буфер обмена
  1.  
  2. SELECT * FROM questions WHERE tema=3 ORDER BY RAND() LIMIT 3
  3. UNIAN ALL
  4. SELECT * FROM questions WHERE tema=2 ORDER BY RAND() LIMIT 2
  5. UNION ALL
  6. SELECT * FROM questions WHERE tema=1 ORDER BY RAND() LIMIT 1;
  7.  


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
dmn
Отправлено: 15 Мая, 2008 - 21:31:21
Post Id



Новичок


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


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




происходит конфликт UNION ALL с ORDER BY RAND()

А с GROUP BY RAND() все работает Улыбка
Не когда не любил эти запросы! Все равно большое спасибо! честно говоря не знал, как несколько запросов одновременно применить!

(Отредактировано автором: 15 Мая, 2008 - 22:01:00)

 
 Top
EuGen Администратор
Отправлено: 16 Мая, 2008 - 09:32:53
Post Id


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


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


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




Точно, приношу извинения, я тупо скопировал. В UNION можно использовать ORDER BY только на общее поле и только в конце.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 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