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;
$$;
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;
$$;