• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ios - 如何在 swift 中使用 dbAccess 的特定字段更新多条记录

[复制链接]
菜鸟教程小白 发表于 2022-12-11 17:01:36 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我想更新多条记录 (DBAccess ORM)。根据特定字段的条件。比如 set city = "Goa"where name = "atul"。

请查看以下 swift 代码,它工作正常。但是如何在不使用 for 循环的情况下通过单个查询来做到这一点。

func updateRecordsByName(userName: String) {

    //like userName = atul;
    let userArr : DBResultSet = User.query().whereWithFormat("name = %@", withParameters:[userName]).fetch();

    for data in userArr {

        (data as! User).city = "Goa";

        (data as! User).commit();
    }
}

请提出完美的解决方案以减少行数/循环数并改进上述查询代码。



Best Answer-推荐答案


也没有办法,除了执行原始 SQL 本身就很危险,尤其是缓存和打开的对象不知道 SQLite 中已更新的值。

循环对象有问题吗?如果它是性能,那么将更新包装在一个事务中,这样会加快它的速度。

    DBTransaction.transaction({ 
         // put all your writes here

         for data in userArr {
             (data as! User).city = "Goa";
             (data as! User).commit();
         }
    }) { 
         // rollback
    }

也升级到 SharkORM,因为它现在已经从 DBAccess 接管:

http://sharkorm.com , https://github.com/sharksync/sharkorm

如果需要,您可以随时向查询模块添加更新功能。或者通过问题提出功能请求。

关于ios - 如何在 swift 中使用 dbAccess 的特定字段更新多条记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38482326/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap