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
  • 5 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 various tables like Student primary id , students name, course Papers paper
I have tables like these two test_table date student test 2012-05-31 Alice Math 2012-05-31
Suppose you have these tables: Table Name: Salesman Fields: S_ID(Primary Key), Name Table Name:
I have three tables, with these fields: classes : class_id | name | grade
I have a MySQL database with these two tables: Tutor(tutorId, initials, lastName, email, phone,
Hey I have 3 tables called STUDENT, COURSE and ENROLLMENT. STUDENT has a PK
I have these two tables: desc students +-----------------------+---------+------+-----+---------+----------------+ | Field | Type | Null
I have three tables, with these fields: classes : class_id | name | grade
I have a the following tables students(sid, sname, age) course(cid, cname, duration) enroll(sid, cid,
I have these tables: comments uid id pid pages pid user users id rank

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.