- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
对于我的用例,我正在处理可通过源唯一键识别的数据,这些数据分解为 n 个(非确定性)目标条目,并加载到 BigQuery 表中以用于分析目的。
构建此 ETL 以使用 Mongo 最近的 Change Stream 功能我想删除 BigQuery 中的所有条目,然后以原子方式加载新条目。
探索 BigQuery DML 我看到一个 MERGE支持操作,但只有 WHEN MATCHED THEN DELETE
或 WHEN MATCHED THEN UPDATE
是可能的。
我对 WHEN MATCHED THEN DELETE, AND FOLLOW BY INSERT 操作感兴趣。
我如何在 BigQuery 中实现此类 ETL,同时在数据可用性和正确性方面尽可能保持原子性或最终一致性。
编辑 1:我想提供一个具体的例子来详细说明。
我对这个数据集唯一性的最低粒度是user_id
。行不是唯一可识别的。
示例
从 mongo 更改流接收到更新的用户对象:
user={_id: "3", name="max", registered="2018-07-05" q=["a", "b", "c"]}
当前 BigQuery.user_q 持有
| user_id | q |
...
| 3 | a |
| 3 | b |
...
转换代码将修改后的用户对象加载到 BigQuery.user_q_incoming
| user_id | q |
| 3 | a |
| 3 | b |
| 3 | c |
在 user_q
和 user_q_incoming
之间合并:
user_q
中属于 user_id 3
的 2 行已删除 user_q_incoming
中属于 user_id 3
的 3 行已插入。user_q
中的其余数据 (...
) 保留原样,未修改。BigQuery.user_q 持有
| user_id | q |
...
| 3 | a |
| 3 | b |
| 3 | c |
...
例如,用户可能会从他的个人资料中删除一个问题。将剩余的行保留为 q=["a", "c"]
。我还需要将其转化为 BigQuery 世界观。
最佳答案
BigQuery DML 支持 INSERT
A MERGE statement is a DML statement that can combine INSERT, UPDATE, and DELETE operations into a single statement and perform the operations atomically.
例如
MERGE dataset.Inventory T
USING dataset.NewArrivals S
ON FALSE
WHEN NOT MATCHED AND product LIKE '%washer%' THEN
INSERT (product, quantity) VALUES(product, quantity)
WHEN NOT MATCHED BY SOURCE AND product LIKE '%washer%' THEN
DELETE
所以,你应该好好使用你的 ETL
EDIT based on more specific details added to question
好的,我明白了——我认为在这种情况下 MERGE 将不适用,因为 INSERT 只能用于 NOT MATCH 子句。在这种情况下,有人可能会想出如何欺骗 MERGE 来工作,但与此同时,下面的解决方案可以实现您想要实现的目标 - 我认为是这样 :o)
CREATE OR REPLACE TABLE `project.dataset.user_q` (user_id INT64, q STRING) AS
SELECT * FROM `project.dataset.user_q`
WHERE NOT user_id IN (SELECT DISTINCT user_id FROM `project.dataset.user_q_incoming`)
UNION ALL
SELECT * FROM `project.dataset.user_q_incoming`
WHERE user_id IN (SELECT DISTINCT user_id FROM `project.dataset.user_q`)
关于mongodb - BigQuery 中的行级原子 MERGE REPLACE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51171517/
我有一个包含数据的表,其中在 A 列中我有一组重复的数据(一个接一个)。 我只想根据 A 列中的值(没有其他条件)选择每个组的第一行。请注意,我还希望为提到的新发现的行选择所有相应的列(我不想排除它们
我有一个包含 340GB 数据的表,但我们只使用了最后一周的数据。因此,为了最小化将这些数据移动到分区表或分片表的成本计划。 我对分片表和分区做了一些实验。我创建了分区表并加载了两天的数据(两个分区)
我想安排将数据从 GCS 存储桶加载到 BigQuery 表。如果我使用 bigquery-transfer 与调度及时的 bigquery-loads 的核心区别是什么? 最佳答案 它们是相同的。
我想安排将数据从 GCS 存储桶加载到 BigQuery 表。如果我使用 bigquery-transfer 与调度及时的 bigquery-loads 的核心区别是什么? 最佳答案 它们是相同的。
我想编写一个 BigQuery 命令行命令来检索 BigQuery 表的最后修改时间。我怎样才能做到这一点? 仅当 BigQuery 表的最后修改日期时间大于某个日期时间时,我才会使用它。 最佳答案
我似乎无法将任何数据从 Socrata 上传到 BigQuery。我收到“加载操作中的 BigQuery 错误:无法连接 BigQuery 服务器。”最初我得到的是 0 错误错误的限制。现在我已将 C
我正在尝试弄清楚是否可以从大查询中导出 hyperloglog 草图并在外部合并它们以进行基数估计。是否有可用的开源库可以轻松解析大型查询草图? 如果不是,是否有任何关于 biq 查询的 hyperl
这是我用作https://cloud.google.com/bigquery/docs/managing-tables#bigquery-copy-table-python的引用的代码: source
构建管道时,源是 BigQueryIO.Read,您会得到一组 TableRow 对象以供使用。 我基本上想对那些 TableRow 对象进行一些小的更改,然后使用 BigQueryIO.Write
BigQuery API Client Libraries 之间有什么区别?和 BigQuery Storage API Client Libraries ? 在 BigQuery Storage R
据我所知,将数据流式传输到 BigQuery 会导致重复行,正如这里提到的 https://cloud.google.com/bigquery/streaming-data-into-bigquery
我在 BigQuery Jobs API 中注意到复制任务: https://developers.google.com/bigquery/docs/reference/v2/jobs#resourc
https://cloud.google.com/bigquery/docs/reference/datatransfer/rest/ 我正在寻找“bigquery 数据传输服务”的 php 客户端库
我正在从 GCS 中的 CSV 文件到 BQ 执行一些 ETL,一切正常,除了日期。我的表中的字段名称是 TEST_TIME,类型是 DATE,所以在 TableRow 中我尝试传递一个 java.u
我已经阅读了 BigQuery 连接器的文档(https://support.google.com/360suite/datastudio/answer/6370296?hl=en)。 我想将自定义查
当两个不同的billing account下有两个project,并且有跨两个project的授权view时,view的查询费用由哪个billing account来计费? 场景:项目 A 包含使用项
所以我有一张购买表: 用户编号 购买时间 数量 我有一张网站上的用户事件表: 用户编号 位置 浏览时间 如何在不超过 purchase_time 的情况下将 purchases 表与 activiti
我有一个 unix 时间戳列,在我的 csv 文件中以毫秒表示。现在,当我将这些数据插入到我的 bigQuery 表中并查询它时,我得到了这个错误 bigQuery not supporting mi
我目前正在将 BigQuery 表提取到 Google Cloud Storage 中的分片 .csv 中——是否有任何方法可以对提取的行进行洗牌/随机化? GCS .csv 将用作 GCMLE 模型
我需要从数据流更新和删除 BigQuery 中的记录。数据来自 Pubsub,并带有标识操作插入、更新、删除 (I、U、D) 的标志。插入不是问题。 有更新和删除的建议吗? 最佳答案 Dataflow
我是一名优秀的程序员,十分优秀!