我现在只是尝试使用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();
?