Javascript 打印 SQL ResultSet 中的第一项不带逗号,然后所有其他带逗号

Javascript print SQL first item in ResultSet without comma, then all others with comma


create procedure my_stored_procedure(TABLE VARCHAR)
  returns varchar
  language javascript
  as
    $$

var sql_col_list = `select distinct key_name from TABLE;`
results = snowflake.execute({sqlText: sql_col_list});

while (results.next())
{
     script += ',' + results.getColumnValue(1) + '\n';
}

当前输出:

, column1
, column2
, column3

期望的输出:

  column1
, column2
, column2

如何在 sql 存储过程中的 javascript 中执行此操作?我不想多次执行查询,因为实际查询是计算密集型的。

您可以添加布尔值检查是否首先:

var sql_col_list = `select distinct key_name from TABLE;`
results = snowflake.execute({sqlText: sql_col_list});

var isFirst = true;

while (results.next())
{
      if(isFirst)
      {
        script += results.getColumnValue(1) + '\n';
        isFirst = false;
        continue;
      }
     script += ',' + results.getColumnValue(1) + '\n';
}

一个较差的事后解决,去掉:

> ',a,b,c'.replace(/^,/,'');
'a,b,c'
>

另一种选择是构建一个包含所需部分的数组,然后使用 join

> ['a','b','c'].join(',\n');
'a,\nb,\nc'
>

如果你想要结尾的换行符:

> ['a','b','c'].join(',\n')+'\n';
'a,\nb,\nc\n'
>

或者您可以让 Snowflake 为您完成:

SELECT listagg( DISTINCT key_name, ',\n') || '\n'
FROM VALUES
   ('apple'),('cat'),('apple'),('cat'),('dog') t(key_name);
LISTAGG( DISTINCT KEY_NAME, ',\N')|| '\N'
apple,\ncat,\ndog\n

使用你的 sp,我将从循环中删除第一个结果,所以它是:

create or replace procedure my_stored_procedure(TABLE VARCHAR)
  returns varchar
  language javascript
  as
    $$

var sql_col_list = `select distinct key_name from TABLE;`
results = snowflake.execute({sqlText: sql_col_list});
var script = '';

results.next()
script += results.getColumnValue(1)

while (results.next())
{
       script += ',' + results.getColumnValue(1) + '\n';
}
return script;
$$;