Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 9240271
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 18, 20262026-06-18T08:09:38+00:00 2026-06-18T08:09:38+00:00

Consider the following relation from the Bars and Beers database: sells (bar, beer, price):

  • 0

Consider the following relation from the Bars and Beers database:

sells (bar, beer, price): indicates the price of each beer sold at each bar (note that each bar can sell many beers and many bars can sell the same beer, at possibly different prices).

The following query finds the name of the minimum price beer that can be found at any bar.

SELECT s.beer
FROM sells s
WHERE NOT EXISTS (SELECT si.beer
FROM sells si
WHERE si.price <= s.price) 

Hi, I am learning sql slowly and I am having trouble understanding the part “si.price <= s.price”. Wouldn’t the entire query always return an empty table since the nested select is basically comparing the same two tables?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-18T08:09:38+00:00Added an answer on June 18, 2026 at 8:09 am

    There is a bug in that query – it will never return any rows, because no price is not equal to itself.

    To work, it should be:

    ...
    WHERE si.price < s.price) 
    

    Assuming that change is made, the explanation of how it works s that the inner query executes once for every row in the table and depends on the outer table (called a “co-related subquery”). Because the same table is used in the inner query, you need to alias the outer table (as “s” in this case). The inner query asserts that there is no (other) price lower than the price in the row being executed.

    Incidentally, aliasing the inner query is unnecessary – you could remove “s1” and it would still work, because the inner query is the default scope:

    SELECT beer
    FROM sells s
    WHERE NOT EXISTS (
        SELECT *
        FROM sells  -- no alias needed
        WHERE price <= s.price)
    

    Further, this is a “bad” query because of the corelated subquery, which causes “n” queries to execute (one for each row). You’re better off using the min() aggregate function:

    SELECT beer
    FROM sells
    WHERE price = (SELECT min(price) FROM sells)
    

    Apart from this query being simpler and easier to understand (two good things), it executes faster because only two queries are executed (one subquery to find the minimum price, and one to get the whole row that has it).

    Finally, the last (albeit minor) bug is that all of these will return multiple rows if there are multiple low-priced beers with the same price. To return the lowest price beer, you would need to limit the number of rows to 1 and decide how to break the tie (perhaps on name). In fact, returning just one row allows for an even simpler query:

    select beer
    FROM sells
    ORDER BY price
    LIMIT 1
    

    And if you needed to consistently break a tie (ie not return a random same-priced beer with the same lowest price), also order by the name:

    select beer
    FROM sells
    ORDER BY price, beer
    LIMIT 1
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Consider following SQL statement - SELECT * FROM Customers WHERE FirstName LIKE '%IS%' This
Let's consider, for instance, the following relation: R ( A,B,C ,D,E,F) where the bold
Consider the following relation to illustrate my question: Person( name, street, city, zipcode )
Consider the following django model from django.db import models from django.contrib import auth class
Consider following piece of code: declare @var bit = 0 select * from tableA
Consider following make: all: a b a: echo a exit 1 b: echo b
Consider following code: My problem is: 1) I can't seem to cast the errors
Consider following string Some string with quotes and \pre-slashed\ quotes Using regex, I want
Consider following text: $content=<<<EOT { translatorID: f4a5876a-3e53-40e2-9032-d99a30d7a6fc, label: ACL, creator: Nathan Schneider, target: ^https?://(www[.])?aclweb\\.org/anthology-new/[^#]+,
Consider following 2 programs giving same error First calss: public class Testing { Testing

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.