4

我正在尝试在 sqlite 中映射一个复杂的类,但似乎有些问题,因为当我检索我的对象时,复杂的字段是空的。很快,我的课是类似的:

 public class Contact
 {
    [PrimaryKey, AutoIncrement]
    public int Id { set; get; }
    public string Name { set; get; }
    public string Status { set; get; }

    [TextBlob("PhoneNumbersBlobbed")]
    public List<PhoneNumber> PhoneNumbers { set; get; }
    public string PhoneNumbersBlobbed { get; set; } // serialized PhoneNumbers

    [TextBlob("MailAddressesBlobbed")]
    public List<ContactEmail> MailAddresses { set; get; }
    public string MailAddressesBlobbed { get; set; } // serialized MailAddresses
 }

我显然有一个单独的电话号码类:

     public class PhoneNumber
     {          
        public string Number { set; get; }
        public bool IsVerified { set; get; }
        public string AttrString { set; get; }  
    }

而 ContactEmail 类是 WinPhone 的原生类。

好吧,在数据库中创建表之后:

 connection.CreateTable<Contact.PhoneNumber>();
 connection.CreateTable<Contact>();

并填充了我的联系人列表,我将它们保存在数据库中。我尝试通过以下方式一一保存:

connection.InsertWithChildren(contact,true);

作为所有列表一起:

connection.InsertAllWithChildren(listOfContacts, true);

而且我确信在保存之前正确填充了列表。但是当我从 sqlite 读取它的值时:

var list = connection.Table<Contact>().ToList();
connection.UpdateAll(list ,true);

我在 PhoneNumbers 和 MailAddresses 字段中看不到值,而在它们的 blobbed 字段中填充了序列化值。

上瘾,试图手动反序列化斑点字段,我从 Json.net 得到一个例外(即以这种方式做):

 foreach (Contact pc in list)
        {
            try
            {
                Contact.PhoneNumber[] numbs = JsonConvert.DeserializeObject<PhoneContact.PhoneNumber[]>(pc.PhoneNumbersBlobbed);
            }
            catch {
                ;
            }
        }

我错了什么?谢谢

4

1 回答 1

2

为了从数据库中检索关系,您必须使用WithChildrenSQLite-Net Extensions 提供的任何方法。

尝试更改这些行:

var list = connection.Table<Contact>().ToList();
connection.UpdateAll(list ,true);

对此:

var list = connection.GetAllWithChildren<Contact>();

您也不需要该PhoneNumber表,因为它们正在 text 属性中进行序列化。所以你可以删除这一行:

connection.CreateTable<Contact.PhoneNumber>();
于 2015-09-15T09:45:40.753 回答