关于STSDB更新对象的几点发现
一,如果表中存储的直接是简单对象,如<key,int>、<key,string>时
使用table[key] = 值即可完成更新;
二,如果表中存储的是类时,更新情况较为复杂,如<int,student>
如果使用
table[1].Name = "XXX";
table[1].Age = 20;
DB.Commit();
发现内存中的值可以被更新掉,只要程序不down,那么数据是更新状态。但是重启后我发现,STSDB的文件并没有更新,通过研究发现必须使用Table的Replace方法更新才行,而且要和开表写在同一段逻辑里面,不能使用方法来更新,例如:
var table = DB.OpenTable<int.student>();
student stu1 = table[1];
//必须在此处更新和提交,不能写到别的地方去
table.Replace(1.stu2);
DB.Commit();
相关文章