powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Использование одного запроса в качестве множества для двух параметров.
7 сообщений из 7, страница 1 из 1
Использование одного запроса в качестве множества для двух параметров.
    #38444328
DeMonyan
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Может невнятно назвал тему, но даже не представляю как это логически ещё можно назвать.

Есть таблица с полями: 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')

Но я совершенно не могу понять как можно в условии указывать именно пару технология/уровень.
...
Рейтинг: 0 / 0
Использование одного запроса в качестве множества для двух параметров.
    #38444364
tanglir
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
DeMonyan,

Код: sql
1.
2.
3.
4.
select t2.*
from table t1
join table t2 on t1.user<>t2.user and t1.tech=t2.tech and t1.level=t2.level
where t1.prize>t2.prize
...
Рейтинг: 0 / 0
Использование одного запроса в качестве множества для двух параметров.
    #38444365
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.
select t1.user x_user, t2.*
  from t t1
  join t t2
    on t1.user != t2.user
   and t1.level = t2.level
   and t1.tech = t2.tech
   and t1.prize > t2.prize
 order by t1.user, t2.user, t2.tech, t2.level
...
Рейтинг: 0 / 0
Использование одного запроса в качестве множества для двух параметров.
    #38444461
DeMonyan
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
tanglirDeMonyan,

Код: sql
1.
2.
3.
4.
select t2.*
from table t1
join table t2 on t1.user<>t2.user and t1.tech=t2.tech and t1.level=t2.level
where t1.prize>t2.prize



Не понял, t1 и t2 - это одна и та же таблица...

Добрый Э - ЭхНе совсем понятно, почему для пользователя aaa именно такой результат.

Если цена не минимально, выводится обладатель минимальной. ) И тот же вопрос... t1 и t2 - это же одна таблица... Я с SQL дружу мягко говоря плохо. )) То что это псевдонимы уже прочитал, но пока не понял где объявлять псевдонимы чего они? В случае выборки из запроса там понятно AS есть, а тут?!
...
Рейтинг: 0 / 0
Использование одного запроса в качестве множества для двух параметров.
    #38444468
Фотография Akina
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
DeMonyant1 и t2 - это же одна таблица...Нет.
Это две НЕЗАВИСИМЫЕ копии одной и той же таблицы. Или, что одно и то же, две РАЗНЫЕ таблицы, имеющие абсолютно одинаковые и структуру, и данные (ибо получены как копии одной и той же таблицы).
...
Рейтинг: 0 / 0
Использование одного запроса в качестве множества для двух параметров.
    #38444497
DeMonyan
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
С псевдонимами разобрался. Но предложенный вариант не работает. Мне нужно по конкретному пользователю выводить данные.
...
Рейтинг: 0 / 0
Использование одного запроса в качестве множества для двух параметров.
    #38444515
DeMonyan
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Спасибо всем. Вроде вот так работает:

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
select * from (select t1.user x_user, t2.* from `user_licens` t1
  join `user_licens` t2
    on t1.user != t2.user
   and t1.level = t2.level
   and t1.tech = t2.tech
   and t1.prize > t2.prize
  where t1.user='DeMonyan'
 order by t1.user, t2.user, t2.tech, t2.level) as foo GROUP BY `level`, `tech`
...
Рейтинг: 0 / 0
7 сообщений из 7, страница 1 из 1
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Использование одного запроса в качестве множества для двух параметров.
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]