Skip to content
Advertisement

Is there any diff between the results of the following tables?

Basic information:Ollivander’s Inventory from Hacker rank

is there any diff between

and

and why we need to join the original table itself to get the right result? I tried to use Product table from w3schools, it returns the same result except the order of data.

Advertisement

Answer

Obviously the two queries look different and would probably generate different execution plans. The queries also are different.

The most important difference is that the first query returns one row for each unique combination of code and power int he database.

The second query will return duplicates if there are two rows that have the same minimum values. In other words, it returns all rows in the original data that have the minimum number of coins for each code/power combination.

A more subtle difference is how NULL values are treated. The first query returns NULL values for code and power. The second filters out the NULL values.

The two queries should return the same results if code and power have no NULL values and if coins_needed is unique on rows with the same code and power. However, those are big assumptions and the queries are not equivalent.

Note that window functions are a simpler way to write the second query:

Well, this is not 100% equivalent because it includes NULL values for code and power.

User contributions licensed under: CC BY-SA
9 People found this is helpful
Advertisement