DBMS_CLOUD_NOTIFICATION 程序包

DBMS_CLOUD_NOTIFICATION 程序包允许您向提供程序发送消息或 SQL 查询的输出。

支持 DBMS_CLOUD_NOTIFICATION 的提供商包括:Email、Microsoft Teams、OCI Notifications (ONS) 和 Slack。

将 OCI Notifications 服务与 DBMS_CLOUD_NOTIFICATION 程序包结合使用时,仅支持 DBMS_CLOUD_NOTIFICATION.SEND_MESSAGE 过程(不支持 DBMS_CLOUD_NOTIFICATION.SEND_DATA 过程)。

Prerequisites

DBMS_CLOUD_NOTIFICATION 子程序概要

此表汇总了程序包中包含的子程序。

子程序 说明
SEND_DATA 过程 将 SQL 查询输出发送到提供程序。
SEND_MESSAGE 过程 将文本消息发送到提供商。

SEND_DATA 过程

SEND_DATA 过程将指定查询的结果发送到提供程序。

语法

DBMS_CLOUD_NOTIFICATION.SEND_DATA(
       provider           IN  VARCHAR2,
       credential_name    IN  VARCHAR2,
       query              IN  CLOB,
       params             IN  CLOB
 );

参数

Parameter (参数) 说明
provider

指定提供方。

有效值为 'email'、'msteams' 和 'slack'

此参数是必需的。

credential_name

要访问提供程序的身份证明对象的名称。

对于电子邮件提供程序,身份证明是 SMTP 批准发件人的身份证明的名称,其中包含其用户名和密码。

对于 msteams 提供程序,凭证是凭证的名称。

对于 Slack 提供程序,凭证的用户名必须为 "SLACK_TOKEN"password 是 Slack 机器人令牌。

此参数是必需的。

query

指定要运行的 SQL 查询。结果将发送到提供商。

此参数是必需的。

params

以 JSON 格式指定 provider 的特定参数。

对于提供程序类型 email,有效参数为:

  • sender. 这以 String 值指定批准的发件人的电子邮件 ID。
  • smtp_host. 这将以 String 值指定 SMTP 主机名。
  • subject. 这以 String 值指定电子邮件的主题。最大大小为 100 个字符。
  • recipient. 这指定 String 值中收件人的电子邮件 ID。存在多个收件人时,在电子邮件 ID 之间使用逗号。
  • to_cc. 这将指定接收电子邮件抄送的电子邮件 ID。这是一个 String 值。存在多个抄送收件人时,在电子邮件 ID 之间使用逗号。
  • to_bcc. 这指定接收电子邮件密件抄送的电子邮件 ID。这是一个 String 值。存在多个密件抄送收件人时,在电子邮件 ID 之间使用逗号。
  • message. 这指定 String 值中的消息文本。
  • type. 这会将 String 值中的输出格式指定为 CSV 或 JSON。
  • title. 这指定 String 值中 SQL 输出的附件的标题。由于标题用于生成文件名,标题应仅包含字母、数字、下划线、连字符或点作为其值的字符。

对于提供程序类型 msteams,有效参数为:

  • tenant. 这将以 String 格式指定租户 ID。
  • team. 这以 String 格式指定团队 ID。
  • channel. 这以 String 格式指定通道 ID。
  • title. 这将以 String 格式指定文件的标题。最大大小为 50 个字符。
  • type. 这以 String 值指定输出格式。有效值为 CSV 或 JSON。

对于提供程序类型 slack,有效参数为:

  • channel. 这指定 String 值中的通道 ID。渠道 ID 是渠道的唯一 ID,与渠道名称不同。在 Slack 中,查看渠道详细信息时,可以在“关于”选项卡上找到渠道 ID。
  • type. 这以 String 值指定输出格式。有效值为 CSV 或 JSON。

此参数是必需的。

使用说明

使用过程 DBMS_CLOUD.CREATE_CREDENTIAL(credential_nameusernamepassword) 创建凭证对象。有关更多信息,请参见 CREATE_CREDENTIAL Procedure

范例

使用 email 提供程序发送 SQL 输出:

BEGIN
    DBMS_CLOUD.CREATE_CREDENTIAL(
    credential_name => 'EMAIL_CRED',
    username        => 'username',
    password        => 'password');
END;
/

BEGIN
   DBMS_CLOUD_NOTIFICATION.SEND_DATA(
        provider        => 'email',
        credential_name => 'EMAIL_CRED',
        query           => 'SELECT tablespace_name FROM dba_tablespaces',
        params          => json_object('recipient' value  'mark@oracle.com, suresh@oracle.com',
                                       'to_cc'  value 'nicole@oracle.com1, jordan@oracle.com',
                                       'to_bcc' value 'manisha@oracle.com',
                                       'subject' value 'Test subject',
                                       'type' value 'json',
                                       'title' value 'mytitle',
                                       'message' value 'This is the message',
                                       'smtp_host' value 'smtp.email.example.com',
                                       'sender'    value  'approver_sender@oracle.com' )
   );
   END;
/

使用 msteams 提供程序发送 SQL 输出:

BEGIN
    DBMS_CLOUD.CREATE_CREDENTIAL(credential_name => 'TEAMS_CRED',
        username        => '*bot_id*',
        password        => '*bot_secret*');
END;
/

BEGIN
     DBMS_CLOUD_NOTIFICATION.SEND_MESSAGE(provider => 'msteams',
        credential_name => 'TEAMS_CRED',
        query           => 'SELECT tablespace_name FROM dba_tablespaces',
        params          => json_object('tenant'value '5b743bc******c0286',
                                       'team'value '0ae401*********5d2bd',
                                       'channel'value '19%3a94be023*****%40thread.tacv2',
                                       'title'value 'today',
                                       'type'value 'csv'));
END;
/

使用 slack 提供程序发送 SQL 输出:

BEGIN
   DBMS_CLOUD.CREATE_CREDENTIAL(
     credential_name => 'SLACK_CRED',
     username        => 'SLACK_TOKEN',
     password        => 'password');
END;
/
BEGIN
  DBMS_CLOUD_NOTIFICATION.SEND_DATA(
      provider        => 'slack',
      credential_name => 'SLACK_CRED',
      query           => 'SELECT username, account_status, expiry_date FROM USER_USERS WHERE rownum < 5',
      params          => json_object('channel' value 'C0....08','type' value 'csv'));
END;
/

SEND_MESSAGE 过程

该过程将文本消息发送到提供程序。

语法

DBMS_CLOUD_NOTIFICATION.SEND_MESSAGE(
       provider           IN  VARCHAR2,
       credential_name    IN  VARCHAR2,
       message            IN  CLOB,
       params             IN  CLOB
 );

参数

Parameter (参数) 说明
provider

指定提供方。

有效值包括:'email'、'msteams'、'slack' 和 'oci'。

此参数是必需的。

credential_name

要访问提供程序的身份证明对象的名称。

对于电子邮件提供程序,身份证明是 SMTP 批准发件人的身份证明的名称,其中包含其用户名和密码。

对于 msteams 提供程序,身份证明必须在用户名和密码中包含 bot_idbot_secret 密钥。

对于 Slack 提供程序,凭证的用户名必须为 "SLACK_TOKEN"password 是 Slack 机器人令牌。

对于 oci 提供程序,身份证明是有效的 Oracle Cloud Infrastructure 签名基于密钥的身份证明。

此参数是必需的。

message

指定消息文本。

此参数是必需的。

params

以 JSON 格式指定 provider 的特定参数。

对于提供程序类型 email,有效参数为:

  • sender. 这以 String 值指定批准的发件人的电子邮件 ID。
  • smtp_host. 这将以 String 值指定 SMTP 主机名。
  • subject. 这以 String 值指定电子邮件的主题。最大大小为 100 个字符。
  • recipient. 这指定 String 值中收件人的电子邮件 ID。存在多个收件人时,在电子邮件 ID 之间使用逗号。
  • to_cc. 这将指定接收电子邮件抄送的电子邮件 ID。存在多个抄送收件人时,在电子邮件 ID 之间使用逗号。
  • to_bcc. 这指定接收电子邮件密件抄送的电子邮件 ID。存在多个密件抄送收件人时,在电子邮件 ID 之间使用逗号。

对于提供程序类型 msteams,有效参数为:

  • channel. 这指定 String 值中的通道 ID。

对于提供程序类型 slack,有效参数为:

  • channel. 这指定 String 值中的通道 ID。

对于类型为 oci 的提供商 OCI Notifications,有效参数为:

  • topic_ocid:指定
  • title:指定消息的主题行。

使用 oci 提供程序时,消息可能有不同的端点,具体取决于订阅。对于不同的订阅,title 参数的处理方式不同:

  • 电子邮件:title 指定消息的主题行。
  • Slack:不使用 title 值。如果包含该值,则忽略该值。

渠道 ID 是渠道的唯一 ID,与渠道名称不同。在 Slack 中,查看渠道详细信息时,可以在“关于”选项卡上找到渠道 ID。

此参数是必需的。

使用说明

使用过程 DBMS_CLOUD.CREATE_CREDENTIAL(credential_nameusernamepassword) 创建凭证对象。有关更多信息,请参见 CREATE_CREDENTIAL Procedure

示例

email 提供程序发送一条短信:

BEGIN
    DBMS_CLOUD.CREATE_CREDENTIAL(
    credential_name => 'EMAIL_CRED',
    username        => 'username',
    password        => 'password');
END;
/

BEGIN
   DBMS_CLOUD_NOTIFICATION.SEND_MESSAGE(
        provider        => 'email',
        credential_name => 'EMAIL_CRED',
        message         => 'Subject content',
        params          => json_object('recipient' value  'mark@oracle.com, suresh@oracle.com',
                                       'to_cc'  value 'nicole@oracle.com, jordan@oracle.com',
                                       'to_bcc' value 'manisha@oracle.com',
                                       'subject' value 'Test subject',
                                       'smtp_host' value 'smtp.email.example.com',
                                       'sender'    value  'approver_sender@oracle.com' )
   );
   END;
/

msteams 提供程序发送一条短信:

BEGIN
    DBMS_CLOUD.CREATE_CREDENTIAL(credential_name => 'TEAMS_CRED',
        username        => '*bot_id*',
        password        => '*bot_secret*');
END;
/

BEGIN
     DBMS_CLOUD_NOTIFICATION.SEND_MESSAGE(
        provider        => 'msteams',
        credential_name => 'TEAMS_CRED',
        message         => 'text from new teams api',
        params          => json_object('channel'value 'C0....08'),'region'value 'india');
END;
/

slack 提供程序发送一条短信:

BEGIN
   DBMS_CLOUD.CREATE_CREDENTIAL(
     credential_name => 'SLACK_CRED',
     username        => 'SLACK_TOKEN',
     password        => 'password');
END;
/
BEGIN
   DBMS_CLOUD_NOTIFICATION.SEND_MESSAGE(
      provider          => 'slack',
      credential_name   => 'SLACK_CRED',
      message           => 'Send text from Autonomous AI Database.',
      params            => json_object('channel' value 'C0....08'));
END;
/

向 OCI Notifications 发送一条短信,键入 oci Provider:

BEGIN
   DBMS_CLOUD_NOTIFICATION.SEND_MESSAGE(
      provider          => 'oci',
      credential_name  => 'OCI_CRED',
      message          => 'Text message for you.',
      params           => json_object('topic_ocid'  value 'oci********pa',
      'title'  value 'Title for message subject' ));
END;
/