Linq to SQL 插入数据时的一个问题

今天用LinqtoSql插入数据,总是插入错误,说某个主键字段不能为空,我检查了半天感觉主键字段没有赋空值啊,实在是郁闷。
要插入数据的表结构是

create table RSSFeedRight
(
    FeedId       
int    Foreign Key (FeedId) References RSSFeed(FeedId) NOT NULL--FeedId ,
    UserId         int    Foreign Key (UserId) References UserInfo(UserId) NOT NULL--UserId ,
    RightValue   bigint NOT NULL Primary key (UserId, FeedId),
)

插入数据的代码

Linq to SQL 插入数据时的一个问题                RSSFeedRight feedRight = new RSSFeedRight();
Linq to SQL 插入数据时的一个问题                feedRight.UserId 
= userId;
Linq to SQL 插入数据时的一个问题                feedRight.FeedId 
= feedId;
Linq to SQL 插入数据时的一个问题                feedRight.RightValue 
= 0;
Linq to SQL 插入数据时的一个问题
Linq to SQL 插入数据时的一个问题                _Db.RSSFeedRights.InsertOnSubmit(feedRight);
Linq to SQL 插入数据时的一个问题                _Db.SubmitChanges();

每次插入时都提示说FeedId 不能插入空值,郁闷的不行,分明是给了非空值的!
后来仔细检查,发现这个RSSFeedRight 实体类中居然还有两个指向UserInfo 和 RSSFeed 表的字段,后来逐渐感觉到是外键设置问题引起的。立即通过google 搜 "linq foreign key insert"
发现有不少人遇到相同问题
找到其中一篇帖子
http://social.msdn.microsoft.com/Forums/en-US/linqprojectgeneral/thread/e14f76ec-0ffe-4dd1-893c-6a4c8440c54a
其中关于这个问题是这样描述的
The mapping information (Assocation attribute on Table1 & Table2) has the foreign key dependency going in the wrong direction.  It's claiming that the primary-key in table1 (the one that is auto-incremented) is a foreign key to the primary key in table2.  You want that just the opposite.  You can change this in the designer, DBML file or directly in the code (for a quick test) by changing IsForeignKey value for both associations.

也就是说我们不能将主键设置为和外键相同,否则就会出问题。找到问题所在,就好办了,将表结构进行如下修改

Linq to SQL 插入数据时的一个问题create table RSSFeedRight
Linq to SQL 插入数据时的一个问题(
Linq to SQL 插入数据时的一个问题    Id   
int    identity(1,1)  NOT NULL    Primary Key,
Linq to SQL 插入数据时的一个问题    FeedId       
int    Foreign Key (FeedId) References RSSFeed(FeedId) NOT NULL--FeedId ,
Linq to SQL 插入数据时的一个问题
    UserId         int    Foreign Key (UserId) References UserInfo(UserId) NOT NULL--UserId ,
Linq to SQL 插入数据时的一个问题
    RightValue   bigint NOT NULL,
Linq to SQL 插入数据时的一个问题)

问题解决。

老兵遇到新问题,技术不经常更新就要老化。





相关文章:

  • 2021-07-15
  • 2021-08-08
  • 2022-03-05
  • 2021-07-30
  • 2022-01-09
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-08-15
  • 2021-05-29
  • 2021-06-09
  • 2021-12-02
  • 2022-02-26
相关资源
相似解决方案