为什么这个简单的对象在插入OrmLite和Sqlite(C#)后没有设置其Id属性

时间:2013-08-26 17:12:21

标签: c# sqlite ormlite

我现在只是尝试使用Ormlite for Sqlite,并遇到了一个问题 - 这个代码虽然简单,但似乎没有更新。

这是一个简单的测试类:

class Person
{
    [AutoIncrement]
    public int Id { get; set; }

    public string FirstName { get; set; }
    public string Surname { get; set; }

    public Person()
    {
    }

    public Person(string firstname, string surname) : this()
    {
        FirstName = firstname;
        Surname = surname;
    }

}

和Ormlite代码:

OrmLiteConfig.DialectProvider = SqliteDialect.Provider;

using (IDbConnection db = "c:/temp/test.sqlite".OpenDbConnection())
{
    db.DropAndCreateTable<Person>();

    var p = new Person("bob", "smith");

    // p.Id property not being set in this Insert
    db.Insert(p);

    p.FirstName = "robert";

    db.Update<Person>(p);

更新:我发现在第一次插入后,Person.Id属性没有更新为自动增量值,并且在手动设置时,更新确实有效。那么,每次插入新记录时,是否需要手动设置Id p.Id = (int) db.GetLastInsertId();

0 个答案:

没有答案