Solved

Can't create strongly typed Controller in MVC

Posted on 2014-02-05
4
1,494 Views
Last Modified: 2014-02-23
I a new to MVC and am trying to create a Controller based on a model that I defined in a class.  I am using EF and have a model based on a SQL Server database.  I need to get data from an ORACLE database and combine it with the data from the SQL Server database.  I can't do this using a View so I have a class that defines the fields I need from the ORACLE database.  When I try and create a controller based on my model I am getting the following error:

Unable to retrieve Metadata for 'ENL.Models.EmployeeExtract'.  One or more validation errors were detected during model generation:

- System.Data.Entity.EdmEntityType: EntityType 'EmployeeExtract' has no key defined.  Define the key for this EntityTYpe.
- System.Data.Entity.Edm.EdmEntitySet: EntityTYpe: ENtitySet 'Employees' is based on type 'EmployeeExtract' that has no keys defined.

Here is my code:
using System.Web;
using System.Data;
using IntranetSupportTeam_i21Login;
using EmployeeProfileDatabase;
using System.Data.Entity;

namespace ENL.Models
{
    public class EmployeeExtract
    {
        public int profileID { get; set; }
        public string firstname { get; set; }
        public string lastname { get; set; }
        public int locationid { get; set; }
        public string emailaddress { get; set; }
        public string homephone { get; set; }
        public string mobilephone { get; set; }
        public string businessmobilephone { get; set; }
    }

    public class EmployeeExtractDbContext : DbContext
    {
        public DbSet<EmployeeExtract> Employees { get; set; }
    }
}

Open in new window


Any help is greatly appreciated!
0
Comment
Question by:dyarosh
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
4 Comments
 
LVL 29

Accepted Solution

by:
Paul Jackson earned 500 total points
ID: 39838647
you need to define the key in the model, if it can't be easily determined which is the key of the model :

using System.Web;
using System.Data;
using IntranetSupportTeam_i21Login;
using EmployeeProfileDatabase;
using System.Data.Entity;

namespace ENL.Models
{
    public class EmployeeExtract
    {
        [Key]
        public int profileID { get; set; }
        public string firstname { get; set; }
        public string lastname { get; set; }
        public int locationid { get; set; }
        public string emailaddress { get; set; }
        public string homephone { get; set; }
        public string mobilephone { get; set; }
        public string businessmobilephone { get; set; }
    }

    public class EmployeeExtractDbContext : DbContext
    {
        public DbSet<EmployeeExtract> Employees { get; set; }
    }
} 

Open in new window

0
 
LVL 29

Expert Comment

by:Paul Jackson
ID: 39838658
The normal configuration of the key is classnameID, so in your case it would be EmployeeExtractID, or you can have just ID. In these cases you wouldn't have to specify the [Key] attribute.
0
 

Author Comment

by:dyarosh
ID: 39838689
Thank you.
0

Featured Post

Enroll in May's Course of the Month

May’s Course of the Month is now available! Experts Exchange’s Premium Members and Team Accounts have access to a complimentary course each month as part of their membership—an extra way to increase training and boost professional development.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Setting up a IIS 8 Web Server to send and receive XML files 7 125
Testing of the web services 1 80
Securing WEBAPI on Azure 2 57
EF5 How do I stop pre-compiled views? 8 57
In .NET 2.0, Microsoft introduced the Web Site.  This was the default way to create a web Project in Visual Studio 2005.  In Visual Studio 2008, the Web Application has been restored as the default web Project in Visual Studio/.NET 3.x The Web Si…
IntroductionWhile developing web applications, a single page might contain many regions and each region might contain many number of controls with the capability to perform  postback. Many times you might need to perform some action on an ASP.NET po…

710 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question