首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >BigQuery是否支持“立即执行”命令来运行动态查询?

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

Stack Overflow用户
提问于 2018-05-14 16:13:05
回答 4查看 7.8K关注 0票数 3

我可以在Oracle中这样编写代码,使用“立即执行.‘”命令动态创建表。

代码语言:javascript
运行
复制
    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函数中可以实现这一点吗?

EN

回答 4

Stack Overflow用户

发布于 2020-10-03 07:29:43

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

代码语言:javascript
运行
复制
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;
票数 4
EN

Stack Overflow用户

发布于 2019-02-27 14:28:45

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

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

BigQuery支持#1,但在撰写本文时,它还没有一个用于#2的EXEC语句。

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

票数 2
EN

Stack Overflow用户

发布于 2018-05-14 17:00:25

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

默认情况下,BigQuery运行交互式查询,这意味着查询将尽快执行。交互式查询计算出您的并发速率限制和每日限制。 BigQuery还提供批处理查询。BigQuery代表您对每个批处理查询进行排队,并在空闲资源可用时(通常在几分钟内)启动查询。如果BigQuery没有在24小时内启动查询,BigQuery就会将作业优先级更改为交互式。批处理查询不包括并发速率限制,这可以使同时启动多个查询更加容易。

这两者都可以在WebUI、命令行、API和客户端中使用。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50334775

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档