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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T16:53:36+00:00 2026-05-11T16:53:36+00:00

I’m trying to build a modified role system that has the following class/relationship structure:

  • 0

I’m trying to build a modified role system that has the following class/relationship structure:

Project
ProjectRole
Employee

where

ProjectEmployee maps the three entities together.

I have a one-to-many mapping from Project to ProjectEmployee and a reference mapping from ProjectEmployee to Project.

I can add new ProjectEmployee’s just fine (which means my Create activities are fine as well), but I want to constrain the relationship to have only one entry per Employee. This affects the logic of my Update activities.

In hacking this together, I am attempting to empty the Project.ProjectEmployees (by setting the value to a new List) and then adding a new instance of ProjectEmployee with the appropriate role, etc.

In doing this, I get an error that is related to setting Project.ProjectEmployees to an empty List.

“Cannot insert the value NULL into column ‘ProjectId’, table ‘AppDB.dbo.ProjectEmployees’; column does not allow nulls. UPDATE fails.
The statement has been terminated.”

If I remove the line that news up the List, the subsequent records get added, but then I’m staring at too many records per employee.

Here’s my Project -> ProjectEmployees mapping:

mapping.HasMany<ProjectEmployee>(x => x.ProjectEmployees)    
    .Cascade.All()
    .WithKeyColumn("ProjectId");

And the mapping in ProjectEmployee -> Project:

mapping.References(x => x.Project, "ProjectId");

Should be simple right?

For what it’s worth, I also added a method to my Project class called AddProjectEmployee that searches for the Employee in question, removes his ProjectEmployee if he exists, then adds the new ProjectEmployee. I get the same error when I call this.

Any help would be appreciated.

Nick

  • 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-05-11T16:53:37+00:00Added an answer on May 11, 2026 at 4:53 pm

    This was cross-posted on the Fluent NHibernate group and answered there by Hudson Akridge. As Hudson said, the solution is to use Clear() on the collection as that allows NHibernate to track the changes (whereas newing up the collection causes the property to reference an instance NH doesn’t know about).

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 234k
  • Answers 234k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer In the main window the category column is the type… May 13, 2026 at 5:58 am
  • Editorial Team
    Editorial Team added an answer Are you looking for something like Select Chain? May 13, 2026 at 5:58 am
  • Editorial Team
    Editorial Team added an answer If it's a custom event, you can put the overrides… May 13, 2026 at 5:58 am

Related Questions

I'm trying to decode HTML entries from here NYTimes.com and I cannot figure out
I want use html5's new tag to play a wav file (currently only supported
I ran into a problem. Wrote the following code snippet: teksti = teksti.Trim() teksti
I've got a string that has curly quotes in it. I'd like to replace
In order to apply a triggered animation to all ToolTip s in my app,

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

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.