|
3 | 3 | <img src="./art/51.png" alt="solution" >
|
4 | 4 |
|
5 | 5 | #### eng:
|
| 6 | +Harry Potter and his friends are at Ollivander's with Ron, finally replacing Charlie's old broken wand. |
6 | 7 |
|
| 8 | +Hermione decides the best way to choose is by determining the minimum number of gold galleons needed to buy each |
| 9 | +non-evil wand of high power and age. Write a query to print the id, age, coins_needed, and power of the wands that |
| 10 | +Ron's interested in, sorted in order of descending power. If more than one wand has same power, sort the result in |
| 11 | +order of descending age. |
7 | 12 |
|
8 | 13 |
|
9 | 14 | #### рус:
|
| 15 | +Гарри Поттер и его друзья находятся у Олливандера с Роном, наконец заменяя старую сломанную палочку Чарли. |
10 | 16 |
|
| 17 | +Гермиона решает, что лучший способ сделать выбор — определить минимальное количество золотых галеонов, необходимое |
| 18 | +для покупки каждой незлой палочки большой силы и возраста. Напишите запрос для вывода идентификатора, возраста, |
| 19 | +требуемых монет и мощности жезлов, которые интересуют Рона, отсортированных в порядке убывания мощности. Если |
| 20 | +несколько жезлов имеют одинаковую силу, отсортируйте результат в порядке убывания возраста. |
11 | 21 |
|
12 | 22 |
|
13 | 23 | #### код с коментариями:
|
14 | 24 | ```sql
|
15 |
| - |
| 25 | +SELECT /* выбрать данные */ |
| 26 | + id, /* столбец */ |
| 27 | + age, /* столбец */ |
| 28 | + coins_needed, /* столбец */ |
| 29 | + power /* столбец */ |
| 30 | +FROM WANDS AS W INNER JOIN WANDS_PROPERTY AS P /* из таблицы объединенной с таблицей */ |
| 31 | +ON W.code = P.code /* по столбцу */ |
| 32 | +WHERE P.is_evil = 0 AND /* где условие1 и */ |
| 33 | +W.coins_needed = (SELECT MIN(coins_needed) /* условие 2 */ |
| 34 | + FROM WANDS AS W1 INNER JOIN WANDS_PROPERTY AS P1 |
| 35 | + ON W1.code = P1.code |
| 36 | + WHERE W.power = W1.power AND P.age = P1.age) |
| 37 | +ORDER BY W.POWER DESC, P.AGE DESC; /* отсортировать по */ |
16 | 38 | ```
|
17 | 39 |
|
18 | 40 | #### код для hackerrank:
|
19 | 41 | ```sql
|
20 |
| - |
| 42 | +SELECT |
| 43 | + id, |
| 44 | + age, |
| 45 | + coins_needed, |
| 46 | + power |
| 47 | +FROM WANDS AS W INNER JOIN WANDS_PROPERTY AS P |
| 48 | +ON W.code = P.code |
| 49 | +WHERE P.is_evil = 0 AND |
| 50 | +W.coins_needed = (SELECT MIN(coins_needed) |
| 51 | + FROM WANDS AS W1 INNER JOIN WANDS_PROPERTY AS P1 |
| 52 | + ON W1.code = P1.code |
| 53 | + WHERE W.power = W1.power AND P.age = P1.age) |
| 54 | +ORDER BY W.POWER DESC, P.AGE DESC; |
21 | 55 | ```
|
22 | 56 |
|
23 | 57 |
|
|
0 commit comments