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

    科技2026-01-30  6

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

       

    Processed: 0.027, SQL: 9