gpt4 book ai didi

go - BigTable 中多列的过滤器

转载 作者:行者123 更新时间:2023-12-01 22:21:15 27 4
gpt4 key购买 nike

来自 CBT 的文档

// READING OP HERE
timestamp := bigtable.Now()
mut := bigtable.NewMutation()
mut.Set(columnFamilyName, "os_name", timestamp, []byte("android"))

filter := bigtable.ChainFilters(
bigtable.FamilyFilter(columnFamilyName),
bigtable.ColumnFilter("os_build"),
bigtable.ValueFilter("PQ2A\\..*"))
conditionalMutation := bigtable.NewCondMutation(filter, mut, nil)

rowKey := "phone#4c410523#20190501"
if err := tbl.Apply(ctx, rowKey, conditionalMutation); err != nil {
return fmt.Errorf("Apply: %v", err)
}

fmt.Println("Successfully updated row's os_name")
我想知道这是否也启用并发控制,即如果我们按顺序进行
#1 - 阅读
#2 - 读取时修改
#3 - 写
如果两个线程同时尝试修改同一行,tbl.Apply 会失败吗?

最佳答案

检查然后作为条件突变写入的过程作为单个原子 Action 完成。如果您要发送多个突变,它们可以按任意顺序执行,但由于 conditionalMutation 是单个操作,它不会受到另一个突变的影响。因此, tbl.Apply 在您的情况下不应失败。

关于go - BigTable 中多列的过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63403977/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com