
Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
29.10.2013, 01:57:59
|
|||
|---|---|---|---|
|
|||
Использование одного запроса в качестве множества для двух параметров. |
|||
|
#18+
Может невнятно назвал тему, но даже не представляю как это логически ещё можно назвать. Есть таблица с полями: id, user, tech, level, prize. tech - технология, level - уровень технологии, prize - цена. Необходимо вывести для данного пользователя все пары технологий и уровней, цена у него которых не минимальна. Проще на примере объяснить. id user tech level prize1 aaa 2 1 10002 aaa 3 1 10003 aaa 3 2 10004 aaa 4 1 10005 aaa 5 1 10006 aaa 6 1 10007 aaa 6 2 10008 bbb 2 1 20009 bbb 3 1 200010 bbb 3 2 50011 bbb 4 1 200012 bbb 5 1 400013 bbb 6 1 300014 bbb 6 2 50015 ccc 6 2 100 Для пользователя aaa результат будет вот таким: 10 bbb 3 2 50015 ccc 6 2 100 Для пользователя bbb результат будет вот таким: 1 aaa 2 1 10002 aaa 3 1 10004 aaa 4 1 10005 aaa 5 1 10006 aaa 6 1 100015 ccc 6 2 100 Для пользователя ccc результат будет пустым. Максимум до чего я дошёл: SELECT * FROM (SELECT * FROM (SELECT * FROM `user_licens` ORDER BY `prize`) as `foo` GROUP BY `level`, `tech`) as `foo1` WHERE `tech` in (SELECT `tech` FROM `user_licens` WHERE `user` = 'aaa') Но я совершенно не могу понять как можно в условии указывать именно пару технология/уровень. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
29.10.2013, 05:13:19
|
|||
|---|---|---|---|
Использование одного запроса в качестве множества для двух параметров. |
|||
|
#18+
DeMonyan, Код: sql 1. 2. 3. 4. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
29.10.2013, 05:13:59
|
|||
|---|---|---|---|
|
|||
Использование одного запроса в качестве множества для двух параметров. |
|||
|
#18+
DeMonyanДля пользователя aaa результат будет вот таким: id user tech level prize10 bbb 3 2 50015 ccc 6 2 100 Не совсем понятно, почему для пользователя aaa именно такой результат. Судя по словесному описанию результат должен быть таким: id user tech level prize10 bbb 3 2 500 14 bbb 6 2 500 15 ccc 6 2 100 Но в целом, решение могло бы выглядеть как-то так: Код: sql 1. 2. 3. 4. 5. 6. 7. 8. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
29.10.2013, 09:39:16
|
|||
|---|---|---|---|
|
|||
Использование одного запроса в качестве множества для двух параметров. |
|||
|
#18+
tanglirDeMonyan, Код: sql 1. 2. 3. 4. Не понял, t1 и t2 - это одна и та же таблица... Добрый Э - ЭхНе совсем понятно, почему для пользователя aaa именно такой результат. Если цена не минимально, выводится обладатель минимальной. ) И тот же вопрос... t1 и t2 - это же одна таблица... Я с SQL дружу мягко говоря плохо. )) То что это псевдонимы уже прочитал, но пока не понял где объявлять псевдонимы чего они? В случае выборки из запроса там понятно AS есть, а тут?! ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
29.10.2013, 09:43:17
|
|||
|---|---|---|---|
Использование одного запроса в качестве множества для двух параметров. |
|||
|
#18+
DeMonyant1 и t2 - это же одна таблица...Нет. Это две НЕЗАВИСИМЫЕ копии одной и той же таблицы. Или, что одно и то же, две РАЗНЫЕ таблицы, имеющие абсолютно одинаковые и структуру, и данные (ибо получены как копии одной и той же таблицы). ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
29.10.2013, 10:03:03
|
|||
|---|---|---|---|
|
|||
Использование одного запроса в качестве множества для двух параметров. |
|||
|
#18+
С псевдонимами разобрался. Но предложенный вариант не работает. Мне нужно по конкретному пользователю выводить данные. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
29.10.2013, 10:21:07
|
|||
|---|---|---|---|
|
|||
Использование одного запроса в качестве множества для двух параметров. |
|||
|
#18+
Спасибо всем. Вроде вот так работает: Код: sql 1. 2. 3. 4. 5. 6. 7. 8. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=47&mobile=1&tid=1835814]: |
0ms |
get settings: |
11ms |
get forum list: |
17ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
75ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
49ms |
get tp. blocked users: |
2ms |
| others: | 224ms |
| total: | 396ms |

| 0 / 0 |
