Triggers class
用于创建、更新插入、查询和读取所有触发器的作。
使用 container.triggers
读取、替换或删除 触发器。
属性
container |
方法
create(Trigger |
创建触发器。 Azure Cosmos DB 支持在创建、更新和删除时执行的 JavaScript 中定义的预先和发布触发器。 有关更多详细信息,请参阅服务器端 JavaScript API 文档。 示例
|
query(Sql |
查询所有触发器。 |
query<T>(Sql |
查询所有触发器。 示例
|
read |
读取所有触发器。 示例 读取数组的所有触发器。
|
属性详细信息
container
方法详细信息
create(TriggerDefinition, RequestOptions)
创建触发器。
Azure Cosmos DB 支持在创建、更新和删除时执行的 JavaScript 中定义的预先和发布触发器。
有关更多详细信息,请参阅服务器端 JavaScript API 文档。
示例
import { CosmosClient, TriggerDefinition, TriggerType, TriggerOperation } from "@azure/cosmos";
const endpoint = "https://your-account.documents.azure.com";
const key = "<database account masterkey>";
const client = new CosmosClient({ endpoint, key });
const { database } = await client.databases.createIfNotExists({ id: "Test Database" });
const { container } = await database.containers.createIfNotExists({ id: "Test Container" });
const triggerDefinition: TriggerDefinition = {
id: "sample trigger",
body: "serverScript() { var x = 10; }",
triggerType: TriggerType.Pre,
triggerOperation: TriggerOperation.All,
};
const { resource: trigger } = await container.scripts.triggers.create(triggerDefinition);
function create(body: TriggerDefinition, options?: RequestOptions): Promise<TriggerResponse>
参数
- body
- TriggerDefinition
- options
- RequestOptions
返回
Promise<TriggerResponse>
query(SqlQuerySpec, FeedOptions)
查询所有触发器。
function query(query: SqlQuerySpec, options?: FeedOptions): QueryIterator<any>
参数
- query
- SqlQuerySpec
作的查询配置。 有关如何配置查询的详细信息,请参阅 SqlQuerySpec。
- options
- FeedOptions
返回
QueryIterator<any>
query<T>(SqlQuerySpec, FeedOptions)
查询所有触发器。
示例
import { CosmosClient } from "@azure/cosmos";
const endpoint = "https://your-account.documents.azure.com";
const key = "<database account masterkey>";
const client = new CosmosClient({ endpoint, key });
const { database } = await client.databases.createIfNotExists({ id: "Test Database" });
const { container } = await database.containers.createIfNotExists({ id: "Test Container" });
const querySpec = {
query: "SELECT * FROM root r WHERE r.id=@id",
parameters: [
{
name: "@id",
value: "<trigger-id>",
},
],
};
const { resources: results } = await container.scripts.triggers.query(querySpec).fetchAll();
function query<T>(query: SqlQuerySpec, options?: FeedOptions): QueryIterator<T>
参数
- query
- SqlQuerySpec
作的查询配置。 有关如何配置查询的详细信息,请参阅 SqlQuerySpec。 *
- options
- FeedOptions
返回
readAll(FeedOptions)
读取所有触发器。
示例
读取数组的所有触发器。
import { CosmosClient } from "@azure/cosmos";
const endpoint = "https://your-account.documents.azure.com";
const key = "<database account masterkey>";
const client = new CosmosClient({ endpoint, key });
const { database } = await client.databases.createIfNotExists({ id: "Test Database" });
const { container } = await database.containers.createIfNotExists({ id: "Test Container" });
const { resources: triggerList } = await container.scripts.triggers.readAll().fetchAll();
function readAll(options?: FeedOptions): QueryIterator<TriggerDefinition & Resource>
参数
- options
- FeedOptions