inding data in a relational database is usually a simple task, especially if you’re simply comparing entries to a specific value, but queries rapidly become more complicated when you start hunting for data that’s missing, in other words, data that could exist, but doesn’t. Missing data is data related to existing data that simply doesn’t occur. You could find missing values using a two-query solution, but SQL’s EXISTS predicate can help you quickly find missing values with just one query?a subquery to be exact.
For example, you may create a query to find active customers by counting recent orders. However, finding inactive customers may be just as important; perhaps you can learn why they’re inactive and perhaps turn them into active customers. In this article, you’ll see how to use the SQL EXISTS predicate to find missing data. This article is aimed at the Jet and Transact-SQL (T-SQL) audience. We’ll offer specific instructions when syntax or rules differ between the two dialects.
Fast Facts |
This article refers to Jet and Transact-SQL. The examples work in Access 97, 2000, and 2002. The T-SQL syntax is correct for SQL Server 2000. |
What Is EXISTS?
SQL’s EXISTS predicate specifies a subquery and then compares a value against the existence of one or more rows in that subquery. The subquery returns True when the subquery contains any rows and False when it doesn’t. However, all of that is probably clear as mud if you’re not familiar with subqueries.
A subquery is a SELECT query within another SELECT, INSERT, UPDATE, DELETE query, or another subquery. In other words, the subquery returns a result set, which is then subject to the main query’s conditions and criteria. Think of the subquery as a filter. The results of the embedded SELECT, also known as the inner query or inner select, become part of the search condition for the main query, otherwise known as the outer query or outer select.
The subquery can take many forms:
SELECT field1?, (subquery) AS alias FROM datasource SELECT fieldlist FROM datasource WHERE field comparison operator (subquery) SELECT fieldlist FROM datasource WHERE field ANY|SOME|ALL (subquery) WHERE expression [NOT] EXISTS (subquery)
In the preceding code, comparison operator equals one of the following: =, <>, <, >, >=, <, !>, !lt;, or <=. When you use one of these comparison operators, the subquery must return a single value. In this article, you'll work with the last form?the one that includes the EXISTS predicate.
Create a Subquery with EXISTS
When combined with EXISTS, an outer query checks for the existence of values within the inner query’s result set. Now, using the Northwind sample database that comes with Access, suppose you want to learn which companies have placed orders. The solution is simple?you don’t need a complex EXISTS solution just yet. The following query returns a unique list of companies with records in the Orders table (see Figure 1):
SELECT DISTINCT Orders.CustomerID FROM Orders
There are 89 companies that have placed at least one order (see Figure 1). The Access query displays the company name instead of the CustomerID value because the CustomerID field in the Orders table is a lookup field. A lookup field is an Access data type that displays a value other than the value that’s actually stored (SQL Server 2000 also supports lookup fields via an ADP front-end).
Figure 2).
The inner query compares the CustomerID value for each record in the Orders table to the CustomerID values in the Customers table. When a matching value is found, the inner query returns True. A True value means the customer has placed an order, but the NOT operator preceding the EXISTS predicate eliminates that particular value from the outer query’s result set. When the inner query doesn’t find any matching records, it returns False. Remember, a False value means the customer hasn’t ordered. The NOT operator then negates that False value, so the outer query can include that record in its result set. The EXISTS predicate finds values that do exist; preceding that predicate with the NOT operator finds those that don’t. Missing data can often be just as informative as data that’s available. Unfortunately, learning what’s missing isn’t always as easy as finding existing data. Combining SQL’s EXISTS predicate with the NOT operator solves the problem and quickly turns up missing information. About Our Editorial ProcessAt DevX, we’re dedicated to tech entrepreneurship. Our team closely follows industry shifts, new products, AI breakthroughs, technology trends, and funding announcements. Articles undergo thorough editing to ensure accuracy and clarity, reflecting DevX’s style and supporting entrepreneurs in the tech sphere. See our full editorial policy. About Our JournalistCharlie Frank Charlie has over a decade of experience in website administration and technology management. As the site admin, he oversees all technical aspects of running a high-traffic online platform, ensuring optimal performance, security, and user experience. View Author Walmart’s fintech startup to disrupt BNPL market Cameron Wiggins April 26, 2024 5:38 PM From humble cart to thriving business: The Nitro Bar’s success story Rashan Dixon April 26, 2024 3:50 PM Adapting business strategies amidst unpredictable economies April Isaacs April 26, 2024 3:11 PM Singaporean entrepreneur’s journey to grocery chain success Cameron Wiggins April 26, 2024 3:06 PM Rhode Island coffee startup finds success April Isaacs April 26, 2024 1:39 PM Erel Margalit’s enduring impact on Israeli tech industry Noah Nguyen April 26, 2024 1:12 PM Bilt Rewards transform US rental sector Cameron Wiggins April 26, 2024 8:58 AM Chinese e-commerce platform upsets US market Noah Nguyen April 26, 2024 8:54 AM Stripe refines business model for fintech competitiveness Johannah Lopez April 26, 2024 7:13 AM Addressing challenges in Israel’s tech sector Rashan Dixon April 25, 2024 5:58 PM Gender disparity challenged by women-centric coworking spaces April Isaacs April 25, 2024 5:56 PM From cart to empire: The Nitro Bar’s rise Cameron Wiggins April 25, 2024 5:23 PM FlexAI nets $30 million to simplify AI computing infrastructure Noah Nguyen April 25, 2024 3:36 PM Google fires 28 protesting employees, maintains professional ethics Johannah Lopez April 25, 2024 1:49 PM Growing interest in small business ownership among millennials Johannah Lopez April 25, 2024 1:31 PM India’s rise in space exploration with private corporations Johannah Lopez April 25, 2024 8:42 AM Walmart partners with fintech One for installment payment service Johannah Lopez April 25, 2024 7:59 AM Biden administration bans noncompete agreements nationwide April Isaacs April 25, 2024 7:01 AM Media mogul poised for $1 billion boost if shares surge Cameron Wiggins April 24, 2024 5:19 PM Bitcoin miners’ strategy stabilizes market pre-halving Noah Nguyen April 24, 2024 5:12 PM Digital banking tackles fraud with advanced methods Johannah Lopez April 24, 2024 1:55 PM Wealth accumulation: Path to personal freedom and societal impact Cameron Wiggins April 24, 2024 1:25 PM Japan’s finance minister warns of currency market intervention Rashan Dixon April 24, 2024 1:14 PM TabaPay set to acquire Synapse’s assets April Isaacs April 24, 2024 11:58 AM Baton Rouge Entrepreneurship Week 2024 announced Cameron Wiggins April 24, 2024 11:36 AM |