微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

为什么 Dexie 在 transaction() 中的 modify() 后返回旧数据?

如何解决为什么 Dexie 在 transaction() 中的 modify() 后返回旧数据?

我对数据库进行了更改并尝试读取更新的数据,但我使用以下代码得到了旧数据:

kera.db.transaction('rw',kera.db.settings,async () => {
    await kera.db.settings.where('name').equals('background')
        .modify({[setting]: value});
    await kera.db.settings.get('background',(data) => {
      console.log(data);
    });
  });

如果我稍后调用相同的 get() 函数,这次我会得到更新的数据。

解决方法

我认为代码中可能还有其他失败的地方。尝试捕捉被拒绝的交易承诺,看看你是否有失败的地方。还要验证闭包变量设置是否正确以及该值是否正确。通过示例,您假设您的主键是 <mosaic-button class="mc-btn" id="btnShowResults btnShowResults " color="secondary" type="button" title="Show results" text="Show results" data-ng-disabled="v1RetrieveService.activeAdvSearchSettings().length < 1 || !isValidForm()" data-ng-click="v1RetrieveService.activeAdvSearchSettings().length < 1 || !isValidForm() || showResults()"> <button type="button" class="mc-btn__button mc-btn__button--secondary" ng-class="{'mc-btn__button--rounded mc-btn__button--icon-only' : rounded,'mc-btn__button--icon-only' : justicon}" aria-label="" ng-disabled="disab"> <!-- ngIf: useIcon --> <div class="mc-btn__div ng-binding" ng-class="{'mc-btn__div--icon-only' : rounded,'mc-btn__div--icon-only' : justicon}"> <!-- ngIf: showSpinner --> Show results </div> </button> </mosaic-button> 。如果不是这种情况,您需要从 db.settings.get('background') 更改为 db.settings.get({name: 'background'})。我试图重现这个问题,但它对我有用:

https://jsitor.com/CV_2VhVvB

,

我清除了页面数据,它突然开始按方面工作。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。