SAP ASE (Sybase)

借助 Sybase 连接器,您可以对 Sybase 执行插入、删除、更新和读取操作。

准备工作

在使用 Sybase 连接器之前,请先完成以下任务:

  • 在您的 Google Cloud 项目中:
    • 向配置连接器的用户授予 roles/connectors.admin IAM 角色。
    • 将以下 IAM 角色授予您要用其来使用连接器的服务账号:
      • roles/secretmanager.viewer
      • roles/secretmanager.secretAccessor

      服务账号是一种特殊类型的 Google 账号,用于表示需要验证身份并获得授权以访问 Google API 数据的非人类用户。如果您没有服务账号,则必须创建一个服务账号。如需了解详情,请参阅创建服务账号

    • 启用以下服务:
      • secretmanager.googleapis.com (Secret Manager API)
      • connectors.googleapis.com (Connectors API)

      如需了解如何启用服务,请参阅启用服务

    如果之前没有为您的项目启用这些服务或权限,则在您配置连接器时,系统会提示您启用。

配置连接器

配置连接器时,您需要创建与数据源(即后端系统)的连接。一个连接需专用于一个数据源。这意味着,如果您有许多数据源,则必须为每个数据源创建单独的连接。如需创建连接,请执行以下步骤:

  1. Cloud 控制台 中,进入 Integration Connectors > 连接页面,然后选择或创建一个 Google Cloud 项目。

    转到“连接”页面

  2. 点击 + 新建以打开创建连接页面。
  3. 位置部分中,选择连接的位置。
    1. 区域:从下拉列表中选择一个位置。

      连接器支持的区域包括:

      如需查看所有受支持区域的列表,请参阅位置

    2. 点击下一步
  4. 连接详情部分中,完成以下操作:
    1. 连接器:从可用连接器的下拉列表中选择 Sybase
    2. 连接器版本:从可用版本的下拉列表中选择一个连接器版本。
    3. 连接名称字段中,输入连接实例的名称。

      连接名称必须符合以下条件:

      • 连接名称可以使用字母、数字或连字符。
      • 字母必须小写。
      • 连接名称必须以字母开头,以字母或数字结尾。
      • 连接名称不能超过 49 个字符。
    4. (可选)输入连接实例的说明
    5. 服务账号:选择具有所需角色的服务账号。
    6. (可选)配置连接节点设置

      • 节点数下限:输入连接节点数下限。
      • 节点数上限:输入连接节点数上限。

      节点是处理事务的连接单元(或副本)。 连接处理越多事务就需要越多节点,相反,处理越少事务需要越少节点。 如需了解节点如何影响连接器价格,请参阅连接节点的价格。如果未输入任何值,则默认情况下,节点数下限设置为 2(以便提高可用性),节点数上限设置为 50。

    7. 数据库:Sybase 数据库的名称。
    8. (可选)点击 + 添加标签,以键值对的形式向连接添加标签。
    9. 点击下一步
  5. 目标部分中,输入要连接到的远程主机(后端系统)的详细信息。
    1. 目标类型:您可以将目标详细信息指定为主机地址或服务连接。选择以下任意目标类型:
      • 主机地址:如果要指定目标的主机名或 IP 地址。
      • 服务连接:如果要为内部 IP 地址指定专用端点。使用服务连接,您可以对外部网络隐藏内部 IP 地址。您可以使用 Private Service Connect 功能在 Google Cloud 中创建服务连接。如需了解如何配置 Private Service Connect,请参阅发布托管式服务

      根据您选择的目标类型,输入主机地址或服务连接名称。

      要输入其他目的地,请点击 +添加目的地

    2. 点击下一步
  6. 身份验证部分中,输入身份验证详细信息。
    1. 选择身份验证类型,然后输入相关详细信息。

      Sybase 连接支持以下身份验证类型:

      • 用户名和密码
    2. 如需了解如何配置这些身份验证类型,请参阅配置身份验证

    3. 点击下一步
  7. 查看:查看您的连接和身份验证详细信息。
  8. 点击创建

配置身份验证

根据您要使用的身份验证输入详细信息。

  • 用户名和密码
    • 用户名:用于身份验证的 Sybase 用户账号。
    • Password:包含用于对用户进行身份验证的密码的 Secret Manager Secret。
    • 密文版本:包含密码的 Secret 的版本。

实体、操作和动作

所有集成连接器都会为所连接应用的对象提供抽象层。您只能通过此抽象访问应用的对象。抽象作为实体、操作和动作向您展示。

  • 实体:实体可以被视为连接的应用或服务中的对象或属性集合。不同连接器的实体定义也会有所不同。例如,在数据库连接器中,表是实体;在文件服务器连接器中,文件夹是实体;在消息传递系统连接器中,队列是实体。

    但可能的情况是,连接器不支持或不具有任何实体,在这种情况下,Entities 列表将为空。

  • 操作:操作是指您可以对实体执行的操作。您可以对实体执行以下任一操作:

    从可用列表中选择一个实体,系统会生成该实体可用的操作列表。如需了解操作的详细说明,请参阅连接器任务的实体操作。不过,如果连接器不支持任何实体操作,则 Operations 列表中不会列出此类不受支持的操作。

  • 动作:动作是可通过连接器接口提供给集成的头等函数。动作可让您对一个或多个实体进行更改,并且动作因连接器而异。通常,操作有一些输入参数和一个输出 参数。但可能的情况是,连接器不支持任何动作,在这种情况下,Actions 列表将为空。

系统限制

Sybase 连接器每秒可处理 2 个事务, 每节点, 并throttles任何事务 。 默认情况下,集成连接器会为连接分配 2 个节点(以提高可用性)。

如需了解适用于 Integration Connectors 的限制,请参阅限制

ExecuteCustomQuery 操作

通过此操作,您可以执行自定义查询。

如需创建自定义查询,请按照下列步骤操作:

  1. 按照详细说明添加连接器任务
  2. 配置连接器任务时,在要执行的动作类型中选择动作
  3. 动作列表中,选择执行自定义查询,然后点击完成

    此图片展示了 execute-custom-query-action 此图片展示了 execute-custom-query-action

  4. 展开任务输入部分,然后执行以下操作:
    1. 在以下时间后超时字段中,输入查询执行前要等待的秒数。

      默认值:180 秒。

    2. 最大行数字段中,输入要从数据库返回的最大行数。

      默认值:25

    3. 要更新自定义查询,请点击修改自定义脚本。系统随即会打开脚本编辑器对话框。

      此图片展示了 custom-sql-query 此图片展示了 custom-sql-query

    4. 脚本编辑器对话框中,输入 SQL 查询,然后点击保存

      您可以在 SQL 语句中使用问号 (?) 表示必须在查询参数列表中指定的单个参数。例如,以下 SQL 查询会从 Employees 表中选择与为 LastName 列指定的值匹配的所有行:

      SELECT * FROM Employees where LastName=?

    5. 如果您在 SQL 查询中使用了问号,则必须点击 + 添加参数名称,针对每个问号添加参数。执行集成时,这些参数按顺序替换 SQL 查询中的问号 (?)。例如,如果您添加了三个问号 (?),那么必须按顺序添加三个参数。

      此图片展示了 add-query-param 此图片展示了 add-query-param

      如需添加查询参数,请执行以下操作:

      1. 类型列表中,选择参数的数据类型。
      2. 字段中,输入参数的值。
      3. 要添加多个参数,请点击 + 添加查询参数

成功执行后,此操作会返回状态 200(OK),并附带包含查询结果的响应正文。

操作示例

本部分介绍如何在此连接器中执行一些操作。

示例 - 创建表格

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. ConnectorTask Input 部分中,点击 Edit Custom Script,然后在 Custom Query 字段:
    CREATE TABLE customqueries98(
         ID   INT ,
         NAME VARCHAR (20),
         AGE  INT,
         City  CHAR (25) ,
         SALARY   DECIMAL (18, 2)  );
  4. 此示例演示如何执行自定义查询以创建新表。 如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数会返回空载荷。

示例 - 修改表

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. 连接器任务输入部分,点击 Edit Custom Script,然后在 Custom Query 字段中输入类似于以下内容的值:
    ALTER TABLE customqueries98 ADD CONSTRAINT ID PRIMARY KEY (ID)
  4. 本示例介绍如何通过执行自定义查询来修改表。 如果操作成功, Execute Custom Query 任务的 connectorOutputPayload 响应 参数会返回空白载荷。

示例 - 截断表

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. 连接器任务输入部分,点击 Edit Custom Script,然后在 Custom Query 字段中输入类似于以下内容的值:
    TRUNCATE TABLE customqueries99
  4. 此示例展示了“执行自定义查询”操作,用于截断表。如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数会返回空白载荷。

示例 - 删除表

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. 连接器任务输入部分中,点击 Edit Custom Script,然后在 Custom Query 字段中输入类似于以下内容的值:
    DROP TABLE customqueries99
  4. 此示例展示了如何使用“执行自定义查询”操作删除表。 如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数会返回空白载荷。

示例 - 验证 SUM

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. ConnectorTask Input 部分中,点击 Edit Custom Script,然后在 Custom Query 字段:
    SELECT SUM(SALARY) as Total FROM EMPLOYEES
  4. 此示例展示了“执行自定义查询”操作,用于验证汇总函数的 SUM 运算。 如果操作成功, Execute Custom Query 任务的 connectorOutputPayload 响应 参数的值类似于以下内容:

    [{
      "Total": 7500.0
      }] 

示例 - 验证 AVG

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. ConnectorTask Input 部分中,点击 Edit Custom Script,然后在 Custom Query 字段:
    SELECT AVG(SALARY) as Average FROM EMPLOYEES
  4. 此示例展示了“执行自定义查询”操作,用于验证汇总函数的 AVG。 如果操作成功, Execute Custom Query 任务的 connectorOutputPayload 响应 参数的值类似于以下内容:

    [{
      "Average": 7500.0
      }] 

示例 - 验证 MAX

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. ConnectorTask Input 部分中,点击 Edit Custom Script,然后在 Custom Query 字段:
    SELECT MAX(SALARY) as Max_Salary FROM EMPLOYEES
  4. 此示例展示如何执行自定义查询来验证汇总函数的 MAX 函数。 如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数的值将类似于以下内容:

    [{
      "Max_Salary": 7500.0
      }] 

示例 - 验证 MIN

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. ConnectorTask Input 部分中,点击 Edit Custom Script,然后在 Custom Query 字段:
    SELECT MIN(SALARY) as Min_Salary FROM EMPLOYEES
  4. 此示例展示了“执行自定义查询”来验证汇总函数的 MIN。 如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数的值将类似于以下内容:

    [{
      "Min_Salary": 7500.0    
      }]

示例 - 验证 COUNT

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. ConnectorTask Input 部分中,点击 Edit Custom Script,然后在 Custom Query 字段:
    select count(*) from EMPLOYEES
  4. 此示例展示了“执行自定义查询”以验证汇总函数的“Count”的用法。 如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数的值将类似于以下内容:

    [{
      "": 1.0
      }]

示例 - 使用 Join 和 GroupBy

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. 连接器任务输入部分,点击 Edit Custom Script,然后在 Custom Query 字段中输入类似于以下内容的值:
    SELECT SmallMoney.amount, Sum(Testsybase.clone) AS Total
      FROM Testsybase
      INNER JOIN SmallMoney
      ON Testsybase.id = SmallMoney.id
      GROUP BY SmallMoney.amount;
  4. 此示例展示了使用 Join 和 GroupBy 执行自定义查询。 如果操作成功, Execute Custom Query 任务的 connectorOutputPayload 响应 参数的值类似于以下内容:

    [{
        "amount": 1122.56,
        "Total": 14.0
      }, {
        "amount": 123.4567,
        "Total": 11.0
      }, {
        "amount": 1123.45,
        "Total": 13.0
      }]

示例 - 使用联接和查询参数

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. ConnectorTask Input 部分中,点击 Edit Custom Script,然后在 Custom Query 字段:
    SELECT e.payload,e.rest,ed.id FROM Testsybase e, Smallmoney ed where e.id=ed.id and ed.id=?
  4. 此示例展示了如何使用 Join 和 Query 参数执行自定义查询。 如果操作成功, Execute Custom Query 任务的 connectorOutputPayload 响应 参数的值类似于以下内容:

     [{
        "payload": 5678.9,
        "rest": 13.6666,
        "id": 2.0
      }] 

示例 - 使用 GroupBy、 has 和 Count

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. 连接器任务输入部分,点击 Edit Custom Script,然后在 Custom Query 字段中输入类似于以下内容的值:
    select payload, count(payload) from Testsybase group by payload having count(payload)>=1
  4. 此示例展示了如何使用 GroupBy、Having 和 Count 执行自定义查询。 如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数的值将类似于以下内容:

    [{
        "payload": 1234.56,
        "": 1.0
      }, {
        "payload": 2345.67,
        "": 1.0
      }, {
        "payload": 4352.78,
        "": 1.0
      }, {
        "payload": 6789.12,
        "": 1.0
      }]

示例 - 使用列转换、LIKE 和其他运算符

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. ConnectorTask Input 部分中,点击 Edit Custom Script,然后在 Custom Query 字段:
    select e.id,e.clone from Testsybase e where e.payload>10 and e.rest LIKE '%1%' AND e.id<>3 order by e.id;
  4. 此示例展示了如何使用列 Cast、LIKE 和其他运算符(例如 <>)执行自定义查询。 如果操作成功, Execute Custom Query 任务的 connectorOutputPayload 响应 参数的值类似于以下内容:

    [{
        "id": 1.0,
        "clone": 10.0
      }, {
        "id": 2.0,
        "clone": 99.0
      }, {
        "id": 4.0,
        "clone": 14.0
      }]

示例 - 通过在集成中提供输入来执行函数

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. 连接器任务输入部分中,点击 Edit Custom Script,然后在 Custom Query 字段中输入类似于以下内容的值:
    SELECT dbo.MultiplyNumbers(5, 10) AS Result
  4. 此示例展示了“执行自定义查询”,用于通过在集成中提供输入来执行函数。 如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数的值将类似于以下内容:

     [{
        "Result": 50.0
      }] 

示例 - 通过在集成中提供输入来创建函数

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. 连接器任务输入部分中,点击 Edit Custom Script,然后在 Custom Query 字段中输入类似于以下内容的值:
    CREATE FUNCTION MultiplyNumbersTest1
      (@num1 INT, @num2 INT) 
      RETURNS INT AS RETURN @num1 * @num2
  4. 此示例展示了通过在集成中提供输入来创建函数的“执行自定义查询”。 如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数会返回空白载荷。

示例 - 在集成中提供输入信息来执行流程

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. 数据映射部分 Open Data Mapping Editor,然后在 Input 字段:
    {
      "@EmpID": 1.0
      } 
      
  4. 此示例展示了“执行自定义查询”操作,用于通过在集成中提供一些输入来执行过程。 如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数的值将类似于以下内容:

     [{
        "EmpID": 1.0,
        "LastName": "Test",
        "FirstName": "Bcone",
        "Address": "Noida",
        "City": "UP"
      }] 
      

示例 - 通过在集成中提供输入来创建过程

  1. Configure Connector 对话框中,选择 Region, Connection and Actions
  2. 从操作中选择 Execute Custom Query,然后点击完成
  3. 连接器任务输入部分中,点击 Edit Custom Script,然后在 Custom Query 字段中输入类似于以下内容的值:
    CREATE PROCEDURE SelectAllEmployees2 @EmpID int
      AS
      SELECT * FROM Employees WHERE EmpID = @EmpID
  4. 此示例展示了通过在集成中提供输入来创建过程的“执行自定义查询”。 如果操作成功,Execute Custom Query 任务的 connectorOutputPayload 响应参数会返回空白载荷。

实体操作示例

本部分介绍如何在此连接器中执行某些实体操作。

示例 - 列出所有记录

  1. Configure connector task 对话框中,点击 Entities
  2. Entity 列表中选择 numbers_table。
  3. 选择 List 操作,然后点击完成

示例 - 从实体中获取记录

  1. Configure connector task 对话框中,点击 Entities
  2. Entity 列表中选择 numbers_table。
  3. 选择 Get 操作,然后点击完成
  4. 将实体 ID 设置为“获取单个数字表”。要设置实体 ID,请在 在 Data MappingData Mapper 部分中,点击 Open Data Mapping Editor,然后 然后在 Input Value(输入值)字段中输入 1.0,并选择 EntityId 作为局部变量。

示例 - 创建记录

  1. Configure connector task 对话框中,点击 Entities
  2. Entity 列表中选择 numbers_table。
  3. 选择 Create 操作,然后点击完成
  4. 任务数据映射器部分中,点击 OpenDataMapping 编辑器,然后在 field: 中输入类似于以下内容的值:
    {
    "bigint_column": 1.2345678901234516E16,
    "usmallint_column": 124.0,
    "numeric_column": 987.664,
    "real_column": 67.88999938964847,
    "uint_column": 125.0,
    "ubigint_column": 1.2345678901234516E16,
    "decimal_column": 124.459,
    "smallint_column": 16.0,
    "int_column": 125.0,
    "floatn_column": 154.45,
    "tinyint_column": 127.0,
    "id": 20.0
    }

    运行此示例,在连接器中返回类似于以下内容的响应 任务的 connectorOutputPayload 输出变量:

    {
    "Success": true 
    }
    

Example - Update a record

  1. In the Configure connector task dialog, click Entities.
  2. Select numbers_table from the Entity list.
  3. Select the Update operation, and then click Done.
  4. Set the entity ID to Update a numbers_table. To set the entity ID, in the Data mapper section of the Tasks, click entityId and then enter 20.0 in the given field.
  5. In the Data mapper section of the Task click OpenDataMapping editor and then enter a value similar to the following in the field:
     
    {
    "uint_column": 128.0,
    "floatn_column": 154.95
    }
  6. 运行此示例,在成功时返回空载荷。

示例 - 从表中删除数据

  1. Configure connector task 对话框中,点击 Entities
  2. Entity 列表中选择 numbers_table。
  3. 选择 Delete 操作,然后点击 完成
  4. 将实体 ID 设置为“Delete numbers_table”。如需设置实体 ID,请在数据映射数据映射器部分,点击打开数据映射编辑器,然后在输入值字段中输入 2.0,并选择 EntityId 作为本地变量。

在集成中使用 Sybase 连接

创建连接后,该连接便可在 Apigee Integration 和 Application Integration。您可以使用连接 通过连接器任务在集成中进行集成。

  • 如需了解如何在 Apigee Integration 中创建和使用连接器任务,请参阅连接器任务
  • 如需了解如何在应用集成中创建和使用连接器任务,请参阅连接器任务

向 Google Cloud 社区寻求帮助

您可以在 Google Cloud 社区的 Cloud 论坛中发布您的问题以及讨论此连接器。

后续步骤