我插入新的实体将通过实体框架的数据库,设置所有属性,但代码仍然抛出我用文字把SQLException:INSERT到DB与实体框架SQLEXCEPTION
无法插入NULL值插入列C_CUSTKEY,表y;列不允许有空值。
但我手动设置所有属性,它们不是null。什么会导致这个问题?
代码:
maxCustomerId = db.Customers.Max(o => o.C_CUSTKEY) + 1;
var customer = new Customer
{
C_CUSTKEY = maxCustomerId,
C_NATIONKEY = 1,
C_NAME = "Peter",
C_ADDRESS = "Praha",
C_COMMENT = "Best customer",
C_ACCTBAL = 0,
C_PHONE = "12345"
};
db.Customers.Add(customer);
db.SaveChanges();
这是我的客户单位:
public class Customer
{
[Key]
public int C_CUSTKEY { get; set; }
public string C_NAME { get; set; }
public string C_ADDRESS { get; set; }
public int C_NATIONKEY { get; set; }
[ForeignKey("C_NATIONKEY")]
public virtual Nation Nation { get; set; }
public string C_PHONE { get; set; }
public decimal C_ACCTBAL { get; set; }
public string C_COMMENT { get; set; }
}
国家实体:
public class Nation
{
[Key]
public int N_NATIONKEY { get; set; }
public string N_NAME { get; set; }
public int N_REGIONKEY { get; set; }
[ForeignKey("N_REGIONKEY")]
public virtual Region Region { get; set; }
public string N_COMMENT { get; set; }
}
地区实体:
public class Region
{
[Key]
public int R_REGIONKEY { get; set; }
public string R_NAME { get; set; }
public string R_COMMENT { get; set; }
}
请在您的问题中发布您的代码,以便我们可以看到什么问题是。 –
您**知道**这样做'SELECT MAX(...)+ 1'来获取您的新**独特的**主键是非常糟糕的?在一个拥有少量并发用户的繁忙系统中,比早些时候更早,你将**重复值** - 这对于主键来说不是一件好事! –
这只是我测试缓存的项目,我没有以任何并发方式使用这个数据库。我是唯一可以访问这个数据库的人。 – MacakM