Data
的构建器。如需为特定类型创建规范,请使用 as...()
方法。如需创建新的构建器,请使用 Spreadsheet
。如需使用该规范,请参阅 Data
。
请仅将此类与连接到数据库的数据搭配使用。
以下示例展示了如何构建 BigQuery 数据源规范。
const spec = SpreadsheetApp.newDataSourceSpec() .asBigQuery() .setProjectId('big_query_project') .setRawQuery('select @FIELD from table limit @LIMIT') .setParameterFromCell('FIELD', 'Sheet1!A1') .setParameterFromCell('LIMIT', 'namedRangeCell') .build();
此示例展示了如何构建 Looker 数据源规范。它会在使用 build()
后返回一个 Looker
对象。
const spec = SpreadsheetApp.newDataSourceSpec() .asLooker() .setInstanceUrl('https://looker_instance_url.com') .setModelName('model_name') .setExploreName('explore_name') .build();
方法
方法 | 返回类型 | 简介 |
---|---|---|
as | Big | 获取 BigQuery 数据源的构建器。 |
as | Looker | 获取 Looker 数据源的构建器。 |
build() | Data | 根据此构建工具中的设置构建数据源规范。 |
copy() | Data | 根据此数据源的设置创建 Data 。 |
get | Data | 获取数据源的参数。 |
get | Data | 获取数据源的类型。 |
remove | Data | 移除所有参数。 |
remove | Data | 移除指定的参数。 |
set | Data | 添加参数;如果存在具有相应名称的参数,则更新类型为 Data 的数据源规范构建器的来源单元格。 |
详细文档
asBigQuery()
asLooker()
获取 Looker 数据源的构建器。
const spec = SpreadsheetApp.newDataSourceSpec() .asLooker() .setInstanceUrl('https://looker_instance_url.com') .setModelName('model_name') .setExploreName('explore_name') .build();
返回
Looker
- Looker 数据源规范构建工具。
build()
根据此构建工具中的设置构建数据源规范。必须先使用 as...()
指定数据源类型,然后才能构建。
以下代码示例会构建 BigQuery DataSource 规范。
const bigQueryDataSourceSpec = SpreadsheetApp.newDataSourceSpec().asBigQuery(); // TODO(developer): Replace with the required dataset, project and table IDs. bigQueryDataSourceSpec.setDatasetId('my data set id'); bigQueryDataSourceSpec.setProjectId('my project id'); bigQueryDataSourceSpec.setTableId('my table id'); bigQueryDataSourceSpec.build();
以下代码示例会构建 Looker 数据源规范。
const lookerDataSourceSpecBuilder = SpreadsheetApp.newDataSourceSpec().asLooker(); const lookerSpec = lookerDataSourceSpecBuilder.setExploreName('my explore name') .setInstanceUrl('my instance url') .setModelName('my model name') .build();
返回
Data
- 数据源规范。
copy()
根据此数据源的设置创建 Data
。
// TODO(developer): Replace the URL with your own. const ss = SpreadsheetApp.openByUrl( 'https://docs.google.com/spreadsheets/d/abc123456/edit', ); const spec = ss.getDataSources()[0].getSpec(); const newSpec = spec.copy();
返回
Data
- 构建器。
getParameters()
获取数据源的参数。
// TODO(developer): Replace the URL with your own. const ss = SpreadsheetApp.openByUrl( 'https://docs.google.com/spreadsheets/d/abc123456/edit', ); const spec = ss.getDataSources()[0].getSpec(); const parameters = spec.getParameters();
此方法仅适用于 BigQuery 数据源。
返回
Data
- 参数列表。
getType()
获取数据源的类型。
// TODO(developer): Replace the URL with your own. const ss = SpreadsheetApp.openByUrl( 'https://docs.google.com/spreadsheets/d/abc123456/edit', ); const spec = ss.getDataSources()[0].getSpec(); const type = spec.getType();
返回
Data
- 数据源类型。
removeAllParameters()
移除所有参数。
const specBuilder = SpreadsheetApp.newDataSourceSpec(); specBuilder.removeAllParameters();
返回
Data
- 用于链接的构建器。
removeParameter(parameterName)
移除指定的参数。
const specBuilder = SpreadsheetApp.newDataSourceSpec(); specBuilder.removeParameter('x');
参数
名称 | 类型 | 说明 |
---|---|---|
parameter | String | 要移除的参数的名称。 |
返回
Data
- 用于链接的构建器。
setParameterFromCell(parameterName, sourceCell)
添加参数;如果具有该名称的参数已存在,则更新类型为 Data
的数据源规范构建器的来源单元格。
此方法仅适用于 BigQuery 数据源。
const specBuilder = SpreadsheetApp.newDataSourceSpec().asBigQuery(); specBuilder.setParameterFromCell('x', 'A1'); const bigQuerySpec = specBuilder.build();
参数
名称 | 类型 | 说明 |
---|---|---|
parameter | String | 参数名称。 |
source | String | 源单元格,如 A1 表示法中所指定。 |
返回
Data
- 用于链接的构建器。