用于在Firebase数据库中添加数量为的项目的Swift代码

用于在Firebase数据库中添加数量为的项目的Swift代码,firebase,firebase-realtime-database,appendchild,swift5.1,product-quantity,Firebase,Firebase Realtime Database,Appendchild,Swift5.1,Product Quantity,使用Swift代码5.1,我已成功使用当前用户篮子中的项目更新Firestore数据库,但无法添加/更新数量。目前,如果我想添加一个已经存在于购物篮中的商品,它只需添加另一行,但我只想更新数量 你能告诉我如何创建一个增加数量的函数吗 这是我目前掌握的代码。仅粘贴代码的相关部分 我的助手文件中的Firestore DB函数: enum FCollectionReference: String { case User case Category case Items case Basket case

使用Swift代码5.1,我已成功使用当前用户篮子中的项目更新Firestore数据库,但无法添加/更新数量。目前,如果我想添加一个已经存在于购物篮中的商品,它只需添加另一行,但我只想更新数量

你能告诉我如何创建一个增加数量的函数吗

这是我目前掌握的代码。仅粘贴代码的相关部分

我的助手文件中的Firestore DB函数:

enum FCollectionReference: String {
case User
case Category
case Items
case Basket
case Orders
    @objc func addToBasketButtonPressed() {
    //check if user is logged in or show login view
    if MUser.currentUser() != nil {

        downloadBasketFromFirestore(MUser.currentId()) { (basket) in
            if basket == nil {
                self.createNewBasket()
            }else {
             basket?.itemIds.append(self.item.id) 
                self.updateBasket(basket: basket!, withValues: [kITEMIDS: basket!.itemIds])

            }
        }
    } else {
        showLoginView()

    }
}

    private func updateBasket(basket: Basket, withValues: [String : Any]) {
    updateBasketInFirestore(basket, withValues: withValues) { (error) in

        if error != nil {
            self.hud.textLabel.text = "Error: \(error!.localizedDescription)"
            self.hud.indicatorView = JGProgressHUDErrorIndicatorView()
            self.hud.show(in: self.view)
            self.hud.dismiss(afterDelay: 2.0)

            print("error updating basket", error!.localizedDescription)

        }else {
            self.hud.textLabel.text = "Added to Basket"
            self.hud.indicatorView = JGProgressHUDSuccessIndicatorView()
            self.hud.show(in: self.view)
            self.hud.dismiss(afterDelay: 2.0)
        }

    }

}
}

}

以下是使用

class Basket {

var id: String!
var ownerId: String!
var itemIds: [String]!
var delivery: Float!
var admin: Float!
var quantity: Int!

init() {
}

init(_dictionary: NSDictionary) {
    id = _dictionary[kOBJECTID] as? String
    ownerId = _dictionary[kOWNERID] as? String
    itemIds = _dictionary[kITEMIDS] as? [String]
    delivery = _dictionary[kDELIVERY] as? Float
    admin = _dictionary[kADMIN] as? Float
    quantity = _dictionary[kQUANTITY] as? Int
}
}

}

func updateBasketInFirestore(uBulk:basket,带值:[String:Any],完成:@escaping(error:error?)->Void){ FirebaseReference(.Basket).document(Basket.id).updateData(withValues){(错误)在中 完成(错误)

项目视图控件中用于将项目添加到购物篮的代码:

enum FCollectionReference: String {
case User
case Category
case Items
case Basket
case Orders
    @objc func addToBasketButtonPressed() {
    //check if user is logged in or show login view
    if MUser.currentUser() != nil {

        downloadBasketFromFirestore(MUser.currentId()) { (basket) in
            if basket == nil {
                self.createNewBasket()
            }else {
             basket?.itemIds.append(self.item.id) 
                self.updateBasket(basket: basket!, withValues: [kITEMIDS: basket!.itemIds])

            }
        }
    } else {
        showLoginView()

    }
}

    private func updateBasket(basket: Basket, withValues: [String : Any]) {
    updateBasketInFirestore(basket, withValues: withValues) { (error) in

        if error != nil {
            self.hud.textLabel.text = "Error: \(error!.localizedDescription)"
            self.hud.indicatorView = JGProgressHUDErrorIndicatorView()
            self.hud.show(in: self.view)
            self.hud.dismiss(afterDelay: 2.0)

            print("error updating basket", error!.localizedDescription)

        }else {
            self.hud.textLabel.text = "Added to Basket"
            self.hud.indicatorView = JGProgressHUDSuccessIndicatorView()
            self.hud.show(in: self.view)
            self.hud.dismiss(afterDelay: 2.0)
        }

    }

}
为了澄清我的请求,我需要在编码中更改/重新安排什么,以便数据库Cloud Firestore按所附屏幕截图中显示的顺序排列。第一个屏幕截图在最后一列显示当前布局,我正在尝试将其更改为第二个屏幕截图中显示的布局


我想你是在问如何更新Firestore文档中某个字段的值。如果没有,请告诉我,我会更新答案

下面是一些更新库存中某个项目数量的代码。传入数量后,将其作为+整数相加,然后作为-整数减去。结构如下所示

root
   inventory
      item_0
         qty: 0
self.incrementQty(deltaQty: 4) //adds 4 to the existing qty
更新数量节点的代码为:

func incrementQty(deltaQty: Int) {
    let docToUpdate = self.db.collection("inventory").document("item_0")

    docToUpdate.updateData( [
        "qty": FieldValue.increment( Int64(deltaQty) )
    ])
}
这样说吧

root
   inventory
      item_0
         qty: 0
self.incrementQty(deltaQty: 4) //adds 4 to the existing qty

以前,必须将递增的值包装到事务中以使其安全,但会使其更容易。

我根据评论和问题澄清添加了另一个答案。我的另一个答案仍然是答案,但这是另一种方法

在NoSQL数据库中,数组本质上很难使用,因为它们通常被视为单个对象。相对于集合、文档和字段,它们的功能有限,无法直接排序或插入项。查询也很有挑战性。Firestore在提供与数组更好的互操作性方面做得很好但通常还有更好的选择

我会将结构更改为以下内容,而不是数组:

Baskets                (collection)
   basket_number       (document in the Baskets collection, like you have now)
      items            //a collection of items in the basket
         item_0        //a document with the docID being the the item number
            item_qty:  //qty of the item
         item_1
            item_qty:
         item_2
            item_qty:
因此.updateData的缺点是,如果要更新的字段不存在,它不会创建字段,它只会抛出一个错误。因此我们需要先测试文档是否存在,如果存在,则使用updateData更新,如果不创建具有初始数量的项

self.incrementQty(itemNumberToUpdate: "item_0", deltaQty: 5)
下面是实现这一点的代码——请注意,为了简单起见,我忽略了顶层的Basket和Basket_编号,因为您已经知道如何完成这一部分,并将重点放在项目集合和向下

func incrementQty(itemNumberToUpdate: String, deltaQty: Int) {
    let docToUpdate = self.db.collection("items").document(itemNumberToUpdate)
    docToUpdate.getDocument(completion: { documentSnapshot, error in
        if let err = error {
            print(err.localizedDescription)
            return
        }

        if let _ = documentSnapshot?.data() {
            print("item exists, update qty")
            docToUpdate.updateData([
                "item_qty": FieldValue.increment( Int64(deltaQty) )
            ], completion: { err in
                if let err = err {
                    print("Error updating document: \(err.localizedDescription)")
                } else {
                    print("Item qty successfully updated")
                }
            })
        } else {
            print("no item exists, need to create")
            docToUpdate.setData([
                "item_qty": FieldValue.increment( Int64(deltaQty) )
            ], completion: { err in
                if let err = err {
                    print("Error updating document: \(err.localizedDescription)")
                } else {
                    print("Item successfully created with initial quantity")
                }
            })
        }
    })
}
传入要修改现有数量的项目编号和数量,或将作为初始数量

self.incrementQty(itemNumberToUpdate: "item_0", deltaQty: 5)

谢谢@Jay。这个功能对我来说是新功能,你已经部分回答了我的查询。我刚刚编辑了我的初始查询,并附上了我的数据库Cloud Firestore的屏幕截图,显示了当前项目如何列在购物篮中(最后一列)最后一个表显示了它应该是什么样子。再次感谢@Jay。您为我提供的解决方案正是我想要的。还有一件事,我如何扩展/修改数据库路径(如下所示)要包括并能够访问屏幕截图中显示的子数据id和数量,我拥有的数据库路径是://MARK:-保存到Firebase func saveBasketToFirestore(ubasket:basket){FirebaseReference(.basket).document(basket.id).setData(basketDictionaryFrom(basket)as![String:Any])}@Nas我不明白下面的问题。你是在问如何为Firestore编写包含多个条目的字典吗?如果你能详细说明一下,我会尝试回答。