用于在Firebase数据库中添加数量为的项目的Swift代码
使用Swift代码5.1,我已成功使用当前用户篮子中的项目更新Firestore数据库,但无法添加/更新数量。目前,如果我想添加一个已经存在于购物篮中的商品,它只需添加另一行,但我只想更新数量 你能告诉我如何创建一个增加数量的函数吗 这是我目前掌握的代码。仅粘贴代码的相关部分 我的助手文件中的Firestore DB函数:用于在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
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编写包含多个条目的字典吗?如果你能详细说明一下,我会尝试回答。