BigQuery是否支持“执行立即”命令来运行动态查询?

时间:2018-05-14 16:13:05

标签: sql oracle google-bigquery execute

我可以在Oracle中使用“执行立即'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函数中实现这一点?

4 个答案:

答案 0 :(得分:2)

是的,BigQuery支持EXECUTE IMMEDIATE命令来运行动态查询。

DECLARE p_dataset_name STRING DEFAULT 'mydataset';
DECLARE p_table_name STRING DEFAULT 'demo';
DECLARE p_column_name STRING DEFAULT 'c1';
DECLARE p_data_type STRING DEFAULT 'string';
DECLARE sydt STRING;
DECLARE qry STRING;
SET sydt = CONCAT(EXTRACT(HOUR from CURRENT_TIMESTAMP()),'_',EXTRACT(MINUTE from CURRENT_TIMESTAMP()),'_',EXTRACT(SECOND from CURRENT_TIMESTAMP()));
SET qry = 'create table '||p_dataset_name||'.'||p_table_name||'_'||sydt||' ('||p_column_name||' '||p_data_type||')';
EXECUTE IMMEDIATE qry;

答案 1 :(得分:1)

有两种“模式”可以在 - interactivebatch中运行BigQuery查询。

  
    

默认情况下,BigQuery运行交互式查询,这意味着查询会尽快执行。交互式查询会计入您的并发费率限制和每日限额。

         

BigQuery还提供批量查询。 BigQuery代表您对每个批处理查询进行排队,并在空闲资源可用时立即启动查询,通常在几分钟内完成。如果BigQuery在24小时内未启动查询,则BigQuery会将作业优先级更改为交互式。批量查询不计入您的并发速率限制,这可以使一次启动多个查询更容易。

  

两者都可在WebUI,命令行,API和客户端中使用

答案 2 :(得分:1)

您必须通过API使用外部呼叫。我为此使用Python。参数基本查询和动态查询。据我所知目前的大查询不支持变量或执行sql命令,直接使用SQL(如TSQL)

答案 3 :(得分:0)

要在SQL中运行动态查询,您需要:

  1. 使用字符串操作和函数构造查询。
  2. 执行构造的字符串作为查询。

BigQuery支持#1,但在撰写本文时,它没有针对#2的EXEC语句。

如果要在BigQuery中运行动态查询,则必须在云函数(或类似环境)中构造字符串,然后通过API将查询发送到BigQuery。