Non sto seguendo esattamente il motivo per cui sto ricevendo questo errore nella mia app MVC5 / EF6 / Code First Migrations. Sto tentando di visualizzare (nel mio elenco degli utenti) il [Nome] dell'organizzazione o il [Nome] dello sponsor a cui l'utente è attualmente associato. Ho le seguenti proprietà definite nel mio IdentityModels.cs :
[GridColumn(Title = "Org.", SortEnabled = true, Width = "100")]
public int? MemberOrgId { get; set; }
[NotMappedColumn]
public int? SponsorOrgId { get; set; }
[NotMappedColumn]
public virtual MemberOrganizations Organization { get; set; }
[NotMappedColumn]
public virtual SponsorOrganizations Sponsor { get; set; }
MemberOrganizations.cs :
[Required]
[Display(Name = "Organization")]
public string Name { get; set; }
[Display(Name = "Users:")]
public virtual ICollection<ApplicationUser> Users { get; set; }
SponsorOrganizations.cs :
[Required]
[Display(Name="Name")]
public string Name { get; set; }
[Display(Name = "Users:")]
public virtual ICollection<ApplicationUser> Users { get; set; }
Questa è la Vista indice con cui sto attualmente lavorando:
@using GridMvc.Html
@model IEnumerable<PROJECTS.Models.ApplicationUser>
@{
ViewBag.Title = "View Users";
Layout = "~/Areas/Admin/Views/Shared/_LayoutAdmin.cshtml";
}
<div class="overflowPrevention">
<!-- Grid.MVC Code -->
<div>
@Html.Grid(Model).Columns(columns =>
{
columns.Add().Encoded(false).Sanitized(false).RenderValueAs(o => Html.ActionLink("Edit", "Edit", "UserManagement", new { id = o.Id }, null)).SetWidth(15);
columns.Add().Encoded(false).Sanitized(false).RenderValueAs(o => o.Name).Titled("Name").Sortable(true).Filterable(true).SetWidth(100);
columns.Add().Encoded(false).Sanitized(false).RenderValueAs(o => o.Position).Titled("Position").Sortable(true).Filterable(true).SetWidth(50);
columns.Add().Encoded(false).Sanitized(false).RenderValueAs(o => o.Email).Titled("Email").Sortable(true).Filterable(true).SetWidth(100);
columns.Add().Encoded(false).Sanitized(false).RenderValueAs(o => o.EmailConfirmed.ToString()).Titled("Confirmed").Sortable(true).Filterable(true).SetWidth(100);
// VALUE TRYING TO RENDER
columns.Add().Encoded(false).Sanitized(false).RenderValueAs(o => o.Organization.ToString()).Titled("MemOrg.").Sortable(true).Filterable(true).SetWidth(25);
// BELOW CORRECTLY RENDERS THE MEMBER ORG ID
columns.Add().Encoded(false).Sanitized(false).RenderValueAs(o => o.MemberOrgId.ToString()).Titled("MemOrg.").Sortable(true).Filterable(true).SetWidth(25);
// BELOW CORRECTLY RENDERS THE SPONSOR ID
columns.Add().Encoded(false).Sanitized(false).RenderValueAs(o => o.SponsorOrgId.ToString()).Titled("Sponsor").Sortable(true).Filterable(true).SetWidth(25);
}).WithPaging(5)
</div>
</div>
Stavo tentando in precedenza columns.Add().Encoded(false).Sanitized(false).RenderValueAs(f => Html.Raw(s => s.Organization.Name));
ma il segmento s => s.Organization.Name
mantenuto risultante in Cannot convert lambda expression to type 'object' because it is not a delegate type
.
Per quanto ne so, la mia riga di codice columns.Add().Encoded(false).Sanitized(false).RenderValueAs(o => o.Organization.ToString()).Titled("MemOrg.").Sortable(true).Filterable(true).SetWidth(25);
dovrebbe essere in grado di rendere correttamente il [Nome] (specificato nel modello da visualizzare come "Organizzazione"), ma quando i carichi Visualizza Ricevo Object reference not set to an instance of an object.
Qualcuno può spiegare che cosa sto facendo in modo errato?
EDIT : ho capito che [User.Organization] (MemberOrganizations.Name) e [User.Sponsor] (SponsorOrganizations.Name) sono effettivamente passati dal mio controller come null. Per ovviare a questo, non sto tentando di scorrere il mio elenco di <ApplicationUser>
e interrogare le tabelle appropriate per riempire il valore attualmente nullo.
Questo è quello che ho finora:
// GET: Admin/UserManagement
public async Task<ActionResult> Index()
{
ViewBag.headerTitle = "User Management";
ViewBag.showCreateButton = true;
ViewBag.createUrl = "/Admin/UserManagement/Create";
ViewBag.createText = " Create a New User";
List<ApplicationUser> model = UserManager.Users.ToList();
foreach (ApplicationUser user in model)
{
if (user.MemberOrgId != null)
{
user.Organization = db.MemberOrganizations.Find(user.Organization);
}
if (user.SponsorOrgId != null)
{
user.Sponsor = db.SponsorOrganizations.Find(user.SponsorOrgId);
}
}
return View(model);
}
user.Sponsor
il primo utente, la proprietà user.Sponsor
finisce per essere:
?user.Sponsor
{System.Data.Entity.DynamicProxies.SponsorOrganizations_F2A27693F33AFF36C814F6FFA2CE63AD656938244F599B7D1AB2ED80CC26EF9A}
[System.Data.Entity.DynamicProxies.SponsorOrganizations_F2A27693F33AFF36C814F6FFA2CE63AD656938244F599B7D1AB2ED80CC26EF9A]: {System.Data.Entity.DynamicProxies.SponsorOrganizations_F2A27693F33AFF36C814F6FFA2CE63AD656938244F599B7D1AB2ED80CC26EF9A}
City: null
Country: null
Enabled: true
FacebookUrl: "https://www.facebook.com/sponsor1"
Id: 1
LogoSrc: "Sponsor1.jpg"
Name: "Sponsor1"
OwnerId: "1d720c20-a508-4880-a5e6-80af5f2f8caf"
OwnerName: "Sponsor Primary"
ProfilePictureUrl: "sponsorprofilepicture/Sponsor1.jpg"
SponsorServiceCategory: Count = 11
State: null
TwitterUrl: "https://twitter.com/sponsor1"
Users: Count = 0
WebsiteUrl: "http://www.sponsor1.com"
Come ottengo la proprietà Name
specificatamente da db.SponsorOrganizations.Find(user.SponsorOrgId)
in user.Sponsor
?
Le proprietà della chiave esterna non sono denominate correttamente in IdentityModels.cs . Le proprietà della chiave esterna devono corrispondere al nome della proprietà di navigazione o è necessario utilizzare l'attributo [ForeignKey]
.
Dovrebbe essere:
[GridColumn(Title = "Org.", SortEnabled = true, Width = "100")]
public int? OrganizationId { get; set; }
[NotMappedColumn]
public virtual MemberOrganizations Organization { get; set; }
o:
[GridColumn(Title = "Org.", SortEnabled = true, Width = "100")]
public int? MemberOrgId { get; set; }
[ForeignKey("MemberOrgId")
[NotMappedColumn]
public virtual MemberOrganizations Organization { get; set; }
o:
[ForeignKey("Organization")
[GridColumn(Title = "Org.", SortEnabled = true, Width = "100")]
public int? MemberOrgId { get; set; }
[NotMappedColumn]
public virtual MemberOrganizations Organization { get; set; }
Potrebbero esserci alcuni problemi con SponsorOrganizations anche perché hai contrassegnato la chiave esterna come non mappata.