[英]Unable to create scheduled query with multiple SQL statements on BigQuery via sdk
我有 2 个 SQL 语句,它们是DELETE
和INSERT
。 INSERT
必须在DELETE
之后运行。 我打算用DELETE...; INSERT...;
DELETE...; INSERT...;
通过 sdk bg mk
声明
但是,我能够使用 sdk 中的仅 1 条语句( DELETE
或INSERT
)成功创建预定查询
bq mk \
--transfer_config \
--project_id='my-proj-id' \
--schedule='every day 00:01' \
--target_dataset='my_dataset' \
--display_name='query_name' \
--params='{"query": "DELETE ..."}' \
--data_source=scheduled_query
当我尝试
bq mk \
--transfer_config \
--project_id='my-proj-id' \
--schedule='every day 00:01' \
--target_dataset='my_dataset' \
--display_name='query_name' \
--params='{"query": "DELETE ...; INSERT ...;"}' \
--data_source=scheduled_query
计划查询已成功创建,但运行失败,出现错误
Error code 9 : Dataset specified in the query ('') is not consistent with Destination dataset 'my_dataset'.
注意:
更新
完整的命令
bq mk \
--transfer_config \
--project_id='my-proj-id' \
--schedule='every day 00:01' \
--target_dataset="my_dataset" \
--display_name='del-insert-test' \
--params="DELETE FROM my-proj-id.my_dataset.my_table WHERE DATE(timestamp) = DATE_ADD(CURRENT_DATE(), INTERVAL -1 DAY); INSERT INTO my-proj-id.my_dataset.my_table SELECT res.col_a, res.col_b, res.col_c, timestamp FROM my-proj-id.my_dataset.my_raw_table, UNNEST (result) as res WHERE DATE(timestamp) = DATE_ADD(CURRENT_DATE(), INTERVAL -1 DAY);" \
--data_source=scheduled_query
请注意,SQL 语句不是实际的,但它是类似的,我能够在云控制台上成功运行 SQL 语句
它对我来说就像一个魅力
bq mk \
--transfer_config \
--project_id='gdglyon-cloudrun' \
--schedule='every day 00:01' \
--target_dataset='dlp_test' \
--display_name='query_name' \
--params='{"query": "DELETE from `gdglyon-cloudrun.dlp_test.name` where id=11;INSERT INTO `gdglyon-cloudrun.dlp_test.name` VALUES (11,111,\"@me.com\");"}' \
--data_source=scheduled_query
你能分享更多关于你的要求吗?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.