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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 26, 20262026-05-26T06:21:03+00:00 2026-05-26T06:21:03+00:00

I have two classes created by Entity Framework based off tables in my db

  • 0

I have two classes created by Entity Framework based off tables in my db

public class AttributeDefinition
{
    int id { get; set; }
    string Type { get; set; }
    string Description { get; set; }
    EntityCollection<AttributeValue> AttributeValues { get; set; }
}

public class AttributeValue
{
    int id { get; set; }
    string Value { get; set; }
    AttributeDefinition AttributeDefinition { get; set; }
}

In the database, the relationship is specified by a foreign key column AttributeDefinitionID in the AttributeValue table.

The case where I want to delete is the following:

if (definition.AttributeValues.Count == 1)
    _db.AttributeValues.DeleteObject(definition.AttributeValues.First());
/*
else if (definition.AttributeValues.Count == 0)
    nothing needs to be done
else if (definition.AttributeValues.Count > 1)
    allow delete of AttributeDefinition, constraint will throw error on save
    which is caught and handled to output error
*/

_db.AttributeDefinitions.DeleteObject(definition);
_db.SaveChanges();

I thought this should work, however it seems to be attempting to delete the AttributeDefinition first, so I get a reference constraint error:

The DELETE statement conflicted with the REFERENCE constraint “FKAttributeV644147”. The conflict occurred in database “Test”, table “dbo.AttributeValue”, column ‘AttributeDefinitionID’.
The statement has been terminated.

If I save between deletes it works fine:

if (definition.AttributeValues.Count == 1)
{
    _db.AttributeValues.DeleteObject(definition.AttributeValues.First());
    _db.SaveChanges();  //Save between deletes
}

_db.AttributeDefinitions.DeleteObject(definition);
_db.SaveChanges();

I DON’T want to use cascade deletes as if there is more than one attribute value assigned to this attribute definition, I want the constraint to throw an exception to say that this can’t be deleted.

Any ideas?

  • 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-26T06:21:04+00:00Added an answer on May 26, 2026 at 6:21 am

    So this may be a special case but I figured I would add the answer just in case people were interested or were looking for it.

    As it turns out, EF hadn’t imported the referential constraint from the DB when updating the model. I worked this out by looking under Constraints in the Model Browser. This led to it not knowing the order to delete entities in when saving to the database.

    Once I had worked that out, I knew from previous experience that if you put a non-clustered index on a primary key that is used in the constraint, EF has a hissy fit and doesn’t import it. See here for details.

    So I simply dropped the index, reimported the constraint, and now it all works as it should.

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

Sidebar

Related Questions

Assume I have the following two classes: public class User : Entity { public
I'm pretty new to MVC 2 using the Entity Framework. I have two tables
Say I have two classes created work and workItem. CWorker *work = new CWorker();
I have created a debugger visualizer in VS2008. There are two classes i've made,
I have two classes, and want to include a static instance of one class
I have two classes, Foo and Bar, that have constructors like this: class Foo
I have two classes declared like this: class Object1 { protected ulong guid; protected
I have two classes: Action and MyAction . The latter is declared as: class
I have two classes: abstract Entity , abstract ClassA extends Entity , ClassB extends
I have the following scenario (in Java / Hibernate): I have two entity classes:

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.