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 905149
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 15, 20262026-05-15T16:10:08+00:00 2026-05-15T16:10:08+00:00

So I have these tables: STUDENTS: Student ID – First name – Last name

  • 0

So I have these tables:

STUDENTS:
Student ID – First name – Last name – Email

COURSES:
Catalog ID – Course Name – Description

TERMS:
Term ID – Start Date – End Date

COURSEINSTANCES:
CourseInstance ID – Catalog ID – Term ID

STUDENTCOURSES:
StudentCourse ID – CourseInstance ID – Student ID – Date added to database

This makes it easy to see which students have taken which courses. I’m not sure how to go about finding out which students have NOT taken a particular course.

Doing something like this:

WHERE ((CourseInstances.CatalogLookup)<>504)

will just give me a list of courses taken by students that do not equal catalog number 504 like this:

Tara – 501

Tara – 502

Tara – 505

John – 503

So for example I’ve taken 504. Therefore I do not want me to show up on this list. The SQL above will just show all of my courses that are not 504, but it will not exclude me from the list.

Any ideas? Is this possible?

  • 1 1 Answer
  • 3 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-05-15T16:10:09+00:00Added an answer on May 15, 2026 at 4:10 pm

    I prefer this syntax over outer joins, IMO it’s easier to read:

    select * 
    from STUDENTS 
    where StudentID not in 
    (
        select StudentID 
        from STUDENTCOURSES s 
        inner join COURSEINSTANCES c on s.CourseInstanceID  = c.CourseInstanceID 
        where c.CatalogID = 504
    )
    

    In the nested query, you select the StudentIDs of all students who HAVE taken course 504.

    Then, you select all the students whose StudentIDs are not included in the nested query.

    EDIT:
    As ChrisJ already said, the c and the s are aliases for the table names.
    Without them, the query would look like this:

    select * 
    from STUDENTS 
    where StudentID not in 
    (
        select StudentID 
        from STUDENTCOURSES 
        inner join COURSEINSTANCES on STUDENTCOURSES.CourseInstanceID = COURSEINSTANCES.CourseInstanceID 
        where CatalogID = 504
    )
    

    I always use aliases because:
    a) I’m too lazy to type the table names more often than necessary.
    b) In my opinion it’s easier to read, especially when you join tables with long names.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have these tables: customer -------- customer_id int name varchar(255) order ----- order_id int
I have a database with 3 tables. The first table contains students with fields
I have these tables: Projects(projectID, CreatedByID) Employees(empID,depID) Departments(depID,OfficeID) Offices(officeID) CreatedByID is a foreign key
I have these 3 tables + data: items : itemId, itemName data: 1, my
Does anyone have any suggestions for creating meta tables in a database? These tables
I have tree tables, Customer, Invoice and InvoiceRow with the standard relations. These I
Say that I have two tables like those: Employers (id, name, .... , deptId).
I have a Relationship table that links teachers to students Teacher Student 1 1
I have an SQL Server DB with a table with these fields: A bit
Suppose I have a dataset with those two immortal tables: Employee & Order Emp

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.