2

使用 LINQ 插入数据库行时,a 0(as an int) 被转换为NULL并且不会显示在插入语句中:

DatabaseCAMAE db = new DatabaseCAMAE(Database.Instance.Connection);
db.Log = Console.Out;
camaeprotocol cpr = new camaeprotocol
{
    sid = 0,
    prrevision = 0,
    ataction = "Scan created",
    prdescription = "Scan created",
    prtimestamp = DateTime.Now,
    uid = 0
};
db.camaeprotocol.InsertOnSubmit(cpr);
db.SubmitChanges();

Wheresidprrevision是主键。
日志输出:

INSERT INTO "main"."camae_protocol"  
   ("at_action", "pr_description", "pr_timestamp", "u_id") 
VALUES (:ataction, :prdescription, :prtimestamp, :uid)
-- :ataction: Input String (Size = 0; Prec = 0; Scale = 0) [Scan created]
-- :prdescription: Input String (Size = 0; Prec = 0; Scale = 0) [Scan created]
-- :prtimestamp: Input DateTime (Size = 0; Prec = 0; Scale = 0) [16.04.2013 07:52:44]
-- :uid: Input Int32 (Size = 0; Prec = 0; Scale = 0) [0]
-- Context: SQLite Model: AttributedMetaModel Build: 0.20.0.0

并引发异常(违反约束),因为 LINQ 不会尝试插入0 sidand 0 prrevision。该怎么做才能解决这个问题?

4

1 回答 1

3

从日志看来,“sid”和“prrevision”字段不包含在 INSERT 语句中。如果您将实体中的这些字段标记为复合主键([Key] 作为注释或流利中的 HasKey()),EF 将不会将它们发送到您的数据库并假定它们是自动生成的。

您可以告诉 EF 不要考虑通过设置自动生成它们

[DatabaseGenerated(DatabaseGenerationOption.None)]

在两个关键领域。

于 2013-04-16T06:30:36.993 回答