当前位置: 首页 > 工具软件 > STSdb > 使用案例 >

关于STSDB更新对象的几点发现

淳于飞文
2023-12-01

一,如果表中存储的直接是简单对象,如<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();

   

 类似资料: