不能将值 NULL 插入列 'U_ID',表 'OA.dbo.Table_User';列不允许有 Null 值。INSERT 失败。语句已终止。
就是增加用户,用户表U_ID是主键,不允许空。下面明明给U_ID赋值了,却还是出错,显示:不能将值NULL插入列'U_ID',表'OA.dbo.Table_UserInf...
就是增加用户,用户表U_ID是主键,不允许空。
下面明明给U_ID赋值了,却还是出错,显示:
不能将值 NULL 插入列 'U_ID',表 'OA.dbo.Table_UserInfo';列不允许有 Null 值。INSERT 失败。 语句已终止
下面是部分代码:
OAEntities oa = new OAEntities();
Table_User user = new Table_User();
user.U_ID = 123;
user.......//user的其他属性赋值;
oa.Table_User.Add(user);
oa.SaveChanges();
网上有人说:一般EF的主键都是系统自动生成的。可能忽略掉了显式赋值,其实一般的套路是主键自增长,然后EF保存时会自动给UID返回数据库里的最新值。
但我这里U_ID设为的是主键,不为空,并且不需要自动增长。我想问的是不改变这种条件的情况下如何解决我的问题。
没分了,望各位大神看看,帮忙解决下,谢谢。 展开
下面明明给U_ID赋值了,却还是出错,显示:
不能将值 NULL 插入列 'U_ID',表 'OA.dbo.Table_UserInfo';列不允许有 Null 值。INSERT 失败。 语句已终止
下面是部分代码:
OAEntities oa = new OAEntities();
Table_User user = new Table_User();
user.U_ID = 123;
user.......//user的其他属性赋值;
oa.Table_User.Add(user);
oa.SaveChanges();
网上有人说:一般EF的主键都是系统自动生成的。可能忽略掉了显式赋值,其实一般的套路是主键自增长,然后EF保存时会自动给UID返回数据库里的最新值。
但我这里U_ID设为的是主键,不为空,并且不需要自动增长。我想问的是不改变这种条件的情况下如何解决我的问题。
没分了,望各位大神看看,帮忙解决下,谢谢。 展开
2个回答
展开全部
因为是主键,可以试试将<generator class="native"></generator>的策略改成"assigned",即把native改为assigned
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
是从来没增加成功过 还是只有123这个有问题呢?
数据表结构是什么样的?U_ID的属性检查一下
数据表结构是什么样的?U_ID的属性检查一下
追问
如果把U_ID设为自动增长,就可以增加成功,关键我不需要设为自动增长,然后就出现这种错误,123只是表示我给U_ID赋值了,结果显示错误说U_ID值为空,不允许插入。
追答
你把你那个表的属性 贴出来看看
就是字段的属性
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询