Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
29.10.2015, 10:22
|
|||
---|---|---|---|
|
|||
INSERT INTO..(SELECT..UNION ALL) |
|||
#18+
Добрый день! Помогите пожалуйста с запросом INSERT INTO TempВопрос ( IdВопрос, НомерВопроса, Вопрос, IdПравОтвет, НомерПравильныйОтвет, idСтудент ) SELECT Вопросы.IdВопрос, Вопросы.НомерВопроса, Вопросы.Вопрос, Вопросы.IdПравОтвет,Вопросы.НомерПравильныйОтвет,Вопросы.idСтудент FROM (SELECT TOP 4 *,Вопросы.IdВопрос, Вопросы.НомерВопроса, Вопросы.Вопрос, Вопросы.IdПравОтвет, Вопросы.НомерПравильныйОтвет, 116 as idСтудент FROM Вопросы WHERE Вопросы.id_RD = 1 ORDER BY rnd(INT(NOW*Вопросы.IdВопрос)-NOW*Вопросы.IdВопрос) UNION ALL SELECT TOP 3 *,Вопросы.IdВопрос, Вопросы.НомерВопроса, Вопросы.Вопрос, Вопросы.IdПравОтвет, Вопросы.НомерПравильныйОтвет, 116 as idСтудент FROM Вопросы WHERE Вопросы.id_RD = 2 ORDER BY rnd(INT(NOW*Вопросы.IdВопрос)-NOW*Вопросы.IdВопрос) ) AS Вопросы; Выдает ошибку В выражении ORDER BY rnd(INT(NOW*Вопросы.IdВопрос)-NOW*Вопросы.IdВопрос) включены поля, не отобранные запросом.Выражение ORDER BY может содержать только поля, затребованные первым запросом. первый select отрабатывает хорошо с rnd, а на втором выдает ошибку. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
29.10.2015, 10:42
|
|||
---|---|---|---|
|
|||
INSERT INTO..(SELECT..UNION ALL) |
|||
#18+
Попробуйте убрать первый ORDER BY (красным). Для UNION указывается однократно - в последней части. Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9.
... |
|||
:
Нравится:
Не нравится:
|
|||
|
29.10.2015, 10:50
|
|||
---|---|---|---|
|
|||
INSERT INTO..(SELECT..UNION ALL) |
|||
#18+
__Michelle, Ту же ошибку выдает ... |
|||
:
Нравится:
Не нравится:
|
|||
|
29.10.2015, 10:59
|
|||
---|---|---|---|
|
|||
INSERT INTO..(SELECT..UNION ALL) |
|||
#18+
DON_DON, Чтобы не сильно заморачиваться, просто, уйти от UNION. Сделай 2 инсерта ... |
|||
:
Нравится:
Не нравится:
|
|||
|
29.10.2015, 11:30
|
|||
---|---|---|---|
|
|||
INSERT INTO..(SELECT..UNION ALL) |
|||
#18+
DON_DON, Что такое NOW? ... |
|||
:
Нравится:
Не нравится:
|
|||
|
29.10.2015, 12:12
|
|||
---|---|---|---|
|
|||
INSERT INTO..(SELECT..UNION ALL) |
|||
#18+
Для UNION действуют такие правила: 1. Имена полей берутся из первого запроса 2. Сортировка берется из последнего. Причем в сортировке нужно указывать только имена полей (без имен таблиц) и указанные поля должны присутствовать в возвращаемом наборе каждого запроса. Во многих случаях это невозможно. Попробуйте добавить в UNION еще один запрос без сортировки, не возвращающий записей. например: Код: sql 1. 2. 3. 4.
Кстати, выделенное во всех запросах, входящих в ваш UNION - лишнее. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
|
start [/forum/topic.php?fid=45&tablet=1&tid=1614356]: |
0ms |
get settings: |
10ms |
get forum list: |
14ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
52ms |
get topic data: |
14ms |
get forum data: |
3ms |
get page messages: |
47ms |
get tp. blocked users: |
2ms |
others: | 12ms |
total: | 160ms |
0 / 0 |