BigQuery是否支持“执行立即”命令来运行动态查询?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BigQuery是否支持“执行立即”命令来运行动态查询?相关的知识,希望对你有一定的参考价值。
我可以在Oracle中编写这样的代码,使用“execute immediate'sql query ...”命令动态创建表。
create or replace function make_a_table1(p_table_name varchar2, p_column_name varchar2, p_data_type varchar2) return varchar2 is
var varchar2(150);
sydt varchar2(30);
pragma autonomous_transaction;
begin
select to_char(sysdate,'HH24_MI_SS') into sydt from dual;
dbms_output.put_line(sydt);
var :='create table '||p_table_name||'_'||sydt||' ( '||p_column_name||' '||p_data_type||')';
dbms_output.put_line(var);
execute immediate var;
commit;
return 'Table Created Successfully';
end;
是否有可能在BigQuery函数中实现这一点?
有两种“模式”可以在-interactive
和batch
中运行BigQuery查询。
默认情况下,BigQuery运行交互式查询,这意味着查询将尽快执行。互动查询会计入您的并发费率限制和每日限额。
BigQuery还提供批量查询。 BigQuery代表您对每个批处理查询进行排队,并在空闲资源可用时立即启动查询,通常在几分钟内完成。如果BigQuery在24小时内未启动查询,则BigQuery会将作业优先级更改为交互式。批量查询不计入您的并发速率限制,这可以使一次启动多个查询更容易。
两者都可以在WebUI,命令行,API和客户端中使用
您必须通过API使用外部呼叫。我为此使用Python。参数基本查询和动态查询。据我所知目前的大查询不支持变量或执行sql命令,直接使用SQL(如TSQL)
要在SQL中运行动态查询,您需要:
- 使用字符串操作和函数构造查询。
- 执行构造的字符串作为查询。
BigQuery支持#1,但在撰写本文时,它没有针对#2的EXEC语句。
如果要在BigQuery中运行动态查询,则必须在云函数(或类似环境)中构造字符串,然后通过API将查询发送到BigQuery。
以上是关于BigQuery是否支持“执行立即”命令来运行动态查询?的主要内容,如果未能解决你的问题,请参考以下文章
如何获取在 BigQuery 命令行工具中运行的最后一个作业的作业 ID?
是否可以针对本地 BigTable 模拟器实例运行 BigQuery 命令行界面 (cli)?