• 0

Setting up Navigation Properties and retrieving info in Entity Framework and MVC 5


Question

Hello neowin community! I know many badasses over here that can help me through my problem. I haven't fully understood how does Lazy loading works in Entity Framework. In fact, I haven't understood how to work with Navigation Properties, Foreign Keys, using Entity Framework at all. I haven't found a tutorial which explains me baby-step by baby-step how is it achieved. So I'm just jerking off code (something I don't like doing).

 

I currently have the following model (Using ASP.NET MVC 5 + Entity Framework 6)

namespace WorldCrowns.Models
{
    /*
     * This is the Contacts Model. This code shall contain all the models for all the friends 
     * */
    public class Contacts
    {
        [HiddenInput(DisplayValue=false)]
        [Key]
        public int ContactsID { get; set; }
        [HiddenInput(DisplayValue=false)]
        public int IboID { get; set; }
        public string Name { get; set; }
        
        [Display(Name="First Time Met")]
        [DataType(DataType.Date)]
        [DisplayFormat(DataFormatString = "{0:yyyy-MM-dd}", ApplyFormatInEditMode = true)]
        public string FirstMeet { get; set; }
        public string Phone { get; set; }
        
        [Display(Name="Date of Contact")]
        [DataType(DataType.Date)]
        [DisplayFormat(DataFormatString = "{0:yyyy-MM-dd}", ApplyFormatInEditMode = true)]
        public DateTime? DateOfContact { get; set; }
        
        public string Comments{ get; set; }
        
        [Display(Name="Next Exposure")]
        [DataType(DataType.Date)]
        [DisplayFormat(DataFormatString = "{0:yyyy-MM-dd}", ApplyFormatInEditMode = true)]
        public DateTime? NextExposure { get; set; }

        [DataType(DataType.Date)]
        [DisplayFormat(DataFormatString = "{0:yyyy-MM-dd}", ApplyFormatInEditMode = true)]
        [Display(Name = "Next Exposure 2")]
        public DateTime? NextExposure2 { get; set; }

        //This is analogue to SelectedQ from Ibo Model
        //The main purpose is to receive the incoming data from the SelectList
        [NotMapped]
        public string SelectedResult { set; get; }

        [Display(Name = "Result")]
        public int ExposureResultID { get; set; }
        public virtual ICollection<ExposureResults> ExposureResult {get; set;}
        //public virtual ICollection<ExposureResults> ExposureResults { get; set; }
        public virtual ICollection<Ibo> Ibo { get; set; }
    }

    public class ExposureResults
    {
        public int ExposureResultsID { get; set; }
        public string ExposureResult { get; set; }
     }
}

so here it is.

 

So, what do I want to achieve?

Easy:

Perform a modified CRUD operation

 

Create a new "Contact" using a dropdown list from the ExposureResults class (which will have data predefined), and read it back. I got the dropdown working, what I'm stuck is making the relation work, so when I get the "ExposureResultID" property, I grab the "ExposureResult" property from ExposureResults Table.

 

 

I've tried to access it like this:

@model IEnumerable<WorldCrowns.Models.Contacts>

@foreach (var item in Model) {
   //I've tried accessing like these:
  //#1

  model.ExposureResultID

  //#2
   model.ExposureResult.ExposureResultsID

   #3
   model.ExposureResult;

   #4
   model.ExposureResult.ExposureResult

}

And haven't managed to get the correct display.

 

Any ideas?

 

Thanks a million! :D

3 answers to this question

Recommended Posts

  • 0
  On 12/10/2014 at 11:17, Riva said:

So if I am understanding correctly, you have a contact that has multiple exposure results. The property Contact.ExposureResultID is not relevant to a one to many relationship.  ExposureResult is the one to use.

Thanks!

 

What I'm trying to say in here is that a "Contact" will have one "ExposureResult" It's a one to one relationship.

  • 0

Riva, I've managed to do as you've said :)

 

I am grabbing now the ID of the row, but not the actual column I want.

 

When I call model.ExposureResult it gives me the ID, how can I do to call the "ExposureResult" column from the "ExposureResult" table?

  • 0
  On 14/10/2014 at 01:12, Jose_49 said:

Thanks!

 

What I'm trying to say in here is that a "Contact" will have one "ExposureResult" It's a one to one relationship.

Sorry.

 

It's a one to many relationship, going from the "ExposureResult" to "Contact" !!!

This topic is now closed to further replies.
  • Posts

    • Get Windows 11 Home or Pro for only $9.97 with this coupon by Steven Parker Today's highlighted deal comes via our Apps + Software section of the Neowin Deals store, where you can save up to 92% off on a Microsoft Windows 11 Home, or Pro license. Upgrade your computing experience with Windows 11 Pro. This cutting-edge operating system boasts a sleek new design and advanced tools to help you work faster and smarter. From creative projects to gaming and beyond, Windows 11 delivers the power and flexibility you need to achieve your goals. With a focus on productivity, the new features are easy to learn and use, enhancing your workflow and efficiency. Whether you're a student, professional, gamer, or creative, Windows 11 Home has everything you need to take your productivity to the next level. New interface. easier on the eyes & easier to use Biometrics login*.Encrypted authentication & advanced antivirus defenses DirectX 12 Ultimate. Play the latest games with graphics that rival reality. DirectX 12 Ultimate comes ready to maximize your hardware* Screen space. Snap layouts, desktops & seamless redocking Widgets. Stay up-to-date with the content you love & the new you care about Microsoft Teams. Stay in touch with friends and family with Microsoft Teams, which can be seamlessly integrated into your taskbar** Wake & lock. Automatically wake up when you approach and lock when you leave Smart App Control. Provides a layer of security by only permitting apps with good reputations to be installed Windows Studio Effects. Designed with Background Blur, Eye Contact, Voice Focus, & Automatic Framing Touchscreen. For a true mouse-less or keyboard-less experience TPM 2.0. Helps prevent unwanted tampering Windows 11 Pro also includes a number of productivity-focused features, such as the ability to snap multiple windows together and create custom layouts, improved voice typing, and a new, more powerful search experience. Personal and professional users will enjoy a modern and secure computing experience, with improved performance and productivity features to help users get more done. Only on Windows 11 Pro If you require enterprise-oriented features for your daily professional tasks, then Windows 11 Pro is a better option. Set up with a local account (only when set up for work or school) Join Active Directory/Azure AD Hyper-V Windows Sandbox Microsoft Remote Desktop BitLocker device encryption Windows Information Protection Mobile device management (MDM) Group Policy Enterprise State Roaming with Azure Assigned Access Dynamic Provisioning Windows Update for Business Kiosk mode Maximum RAM: 2TB Maximum no. of CPUs: 2 Maximum no. of CPU cores: 128 Good to know This license is for Windows 11 only. It is NOT intended to be used for upgrading Microsoft Office (MSO) included in Parallels Pro. However, it will still work with Parallels Pro and allow you to run Windows applications including MSO, but it DOES NOT include an upgrade MSO itself. It is still compatible with Microsoft Office ONLY if you have a separate license for it. Length of access: lifetime Redemption deadline: redeem your code within 30 days of purchase Access options: desktop Max number of device(s): 1 Version: Windows 11 Pro Updates included Click here to verify Microsoft partnership For example, a Microsoft Windows 11 Pro license normally costs $199, but you can pick it up for just $14.97 for a limited time, that represents a saving of $184. For a full description, specs, and license info, click the link below. Get Windows 11 Home or Pro for just $9.97 use MSO5 coupon when checking out Coupon expires on June 29. Although priced in U.S. dollars, this deal is available for digital purchase worldwide. We post these because we earn commission on each sale so as not to rely solely on advertising, which many of our readers block. It all helps toward paying staff reporters, servers and hosting costs. Other ways to support Neowin Whitelist Neowin by not blocking our ads Create a free member account to see fewer ads Make a donation to support our day to day running costs Subscribe to Neowin - for $14 a year, or $28 a year for an ad-free experience Disclosure: Neowin benefits from revenue of each sale made through our branded deals site powered by StackCommerce.
    • I hoped it was a bug and will be fixed. Why haven't they made so it asks for a PIN in the dark then? It tries to use the camera for several minutes or I have to manually select PIN and the next day in the morning I'll have to manually select the camera back, because it will just be sitting and waiting for a PIN. It just remembers the last used method regardless of the lighting.
    • I would recommend PowerToys just to remap a Copilot button on modern laptops for something more useful than Microsoft allows in Windows Settings. I also use some other tools like "Always on Top" and "Crop and Lock".
    • Makes sense, we know MS doesn't take dark mode seriously, lol.
    • Why would you think Johny Ives is behind this ? he has not worked at Apple or on a smart Phone or Phone in general for long time On 27 June 2019, Apple announced that Ive would depart Apple after 27 years
  • Recent Achievements

    • Veteran
      1337ish went up a rank
      Veteran
    • Rookie
      john.al went up a rank
      Rookie
    • Week One Done
      patrickft456 earned a badge
      Week One Done
    • One Month Later
      patrickft456 earned a badge
      One Month Later
    • One Month Later
      Jdoe25 earned a badge
      One Month Later
  • Popular Contributors

    1. 1
      +primortal
      640
    2. 2
      ATLien_0
      275
    3. 3
      +FloatingFatMan
      171
    4. 4
      Michael Scrip
      155
    5. 5
      Steven P.
      138
  • Tell a friend

    Love Neowin? Tell a friend!