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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 13, 20262026-06-13T23:18:23+00:00 2026-06-13T23:18:23+00:00

I have two models, Benefit and SchemeName Benefit – [Key] public int BenefitID {

  • 0

I have two models, Benefit and SchemeName

Benefit –

[Key]
public int BenefitID { get; set; }
public string BenefitName { get; set; }
public string BenefitDescription { get; set; }
public virtual ICollection<SchemeName> SchemeNames { get; set; }

SchemeName

[Key]
public int SchemeNameID { get; set; }
public string Name { get; set; }
public virtual ICollection<Benefit> Benefits { get; set; }

This has created three tables in the database Benefits, SchemeNames and a joining table called SchemeNameBenefits.

I am trying to populate a droplownlist that contains only the SchemeNames associated with a certain Benefit but am not sure how I can do this, can I reference the join table in my code?

I started with the following (which returns all SchemeNames)

private void PopulatePensionSchemeName(object selectedPensionSchemeName = null)
        {
            var schemeNameQuery = from d in db.SchemeNames
                                  orderby d.SchemeNameID
                                  select d;

            ViewBag.PensionSchemeNameID = new SelectList(schemeNameQuery, "SchemeNameID", "Name", selectedPensionSchemeName);
        }

But I’m not sure how I can add this clause. Any pointers?

  • 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-13T23:18:23+00:00Added an answer on June 13, 2026 at 11:18 pm

    You’ll need the key of the Benefit object you want the SchemeNames for. The query you’re probably looking for is:-

    var benefitId = // However you get your benefit Id
    
    var schemaNameQuery = from b in db.Benefits
                          from s in b.SchemeNames
                          where b.BenefitId == benefitId
                          select s;
    

    Or in the extension method syntax:-

    var schemaNameQuery = db.Benefits.Where(b.BenefitId == benefitId)
                                     .SelectMany(b => b.SchemeNames);
    

    Which produces the following SQL:-

    SELECT ...
    FROM [dbo].[SchemeNameBenefits] AS [Extent1]
    INNER JOIN [dbo].[SchemeNames] AS [Extent2]
      ON [Extent1].[SchemeName_Id] = [Extent2].[SchemeNameId]
    WHERE [Extent1].[Benefit_Id] = @p__linq__0
    

    Alternately you can use:-

    var benefitId = // However you get your benefit Id
    
    var schemeNameQuery = from d in db.SchemeNames
                          where d.Benefits.Any(x => x.Id == benefitId)
                          orderby d.SchemeNameId
                          select d;
    

    This produces the following SQL:-

    SELECT ...
    FROM ( SELECT ... FROM [dbo].[SchemeNames] AS [Extent1]
           WHERE EXISTS (SELECT 1 AS [C1]
                         FROM [dbo].[SchemeNameBenefits] AS [Extent2]
                         WHERE ([Extent1].[SchemeNameId] = [Extent2].[SchemeName_Id])
                         AND ([Extent2].[Benefit_Id] = @p__linq__0)))
    AS ...
    ORDER BY [Project2].[Id] ASC
    

    Note that in both cases the generated SQL references your junction table even though it isn’t part of your EF model.

    If you already have the Benefit object, of course, you can get its SchemeNames more simply by using:-

    var schemeNameQuery = benefit.SchemeNames;
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have two models: public class ProfessorModels { public string FullName { get; set;
I have two models, Listing and Invitation, associated with has_and_belongs_to_many. I am looking at
I have two Models, Programme and Event, a programme has many events. I need
I have two models: User and Car with the following associations: User has_many Car
I have two models User and Category that have a HABTM association. I would
I have two models, Landscape: class Landscape < ActiveRecord::Base has_many :images, :as => :imageable
I have two models: class Contact(models.Model): name = models.CharField(max_length=255) class Campaign(models.Model): contact = models.ForeignKey(Contact,
I have two models like this: class ClassA(models.Model): ida = models.AutoField(primary_key=True) classb = models.ForeignKey(ClassB)
I have two models in my Django application, for the purposes of storing search
I have two models, A and B, and one light, L. I would like

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.