GaussDB-ALTER SERVER

64 阅读2分钟

GaussDB-ALTER SERVER

功能描述

增加、修改和删除一个现有server的参数。现有server可以从pg_foreign_server系统表查询。

注意事项
  • 只有server的所有者或者被授予了server的ALTER权限的用户才可以执行ALTER SERVER命令,系统管理员默认拥有该权限。但要修改server的所有者,当前用户必须是该server的所有者或者系统管理员,且该用户是新所有者角色的成员。
  • OPTIONS中的敏感字段(如password、secret_access_key)在使用多层引号时,语义和不带引号的场景是不同的,因此不会被识别为敏感字段进行脱敏。
语法格式
  • 修改外部服务的参数。

| ``` ALTER SERVER server_name [ VERSION 'new_version' ] [ OPTIONS ( {[ ADD | SET | DROP ] option ['value']} [, ... ] ) ];

| --------------------------------------------------------------------------------------------------------------------------------- |

![](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/f30b7dd064b944a68e3d8073303625ee~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAgamVycnl3YW5nMTk4Mw==:q75.awebp?rk3s=f64ab15b&x-expires=1782180031&x-signature=lGavjx%2BZOFBrRfHV%2F6FUyFqEG0Y%3D)

在OPTIONS选项里,ADD、SET和DROP指定要执行的操作,未指定时默认为ADD操作。option和value为对应操作的参数。

-   修改外部服务的所有者。

| ```
ALTER SERVER server_name      OWNER TO new_owner; 
``` |
| ---------------------------------------------------------- |

![](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/5f1896832c054f7b9d32e290f50015e6~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAgamVycnl3YW5nMTk4Mw==:q75.awebp?rk3s=f64ab15b&x-expires=1782180031&x-signature=Rd54usaHQdM6sKJxW%2Fqr4HoePGs%3D)

-   修改外部服务的名称。

| ```
ALTER SERVER server_name      RENAME TO new_name; 
``` |
| ---------------------------------------------------------- |

![]()

#### 参数说明

-   **server_name**

    所修改的server的名称。

-   **new_version**

    修改后server的新版本名称。

-   **OPTIONS**

    更改该服务器的选项。ADD、SET和 DROP指定要执行的动作。如果没有显式地指定操作, 将会假定为ADD。选项名称必须唯一,名称和值也会使用该服务器的外部数据包装器库进行验证。

    修改server所支持的OPTIONS如下所示:

    -   encrypt

        []()[]()是否对数据进行加密,该参数仅支持在type为OBS时设置。默认值为off。

        取值范围:

        -   on表示对数据进行加密。
        -   off表示不对数据进行加密。

    -   access_key

        []()[]()OBS访问协议对应的AK值(OBS云服务界面由用户获取)。该参数仅支持type为OBS时设置。

    -   secret_access_key

        []()[]()OBS访问协议对应的SK值(OBS云服务界面由用户获取)。该参数仅支持type为OBS时设置。

-   **new_owner**

    修改后server的新拥有者。更改所有者,你必须是外部服务器的所有者并且也是新的所有者角色的直接或者间接成员,并且你必须对外部服务器的外部数据封装器有USAGE权限。

-   **new_name**

    修改后server的新名称。

#### 示例

| ```
--创建my_server。 gaussdb=# CREATE SERVER my_server FOREIGN DATA WRAPPER log_fdw;   --修改外部服务的名称。 gaussdb=# ALTER SERVER my_server RENAME TO my_server_1;   --删除my_server_1。 gaussdb=# DROP SERVER my_server_1; 
``` |
| -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |

#### 相关链接

[CREATE SERVER](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/devg-dist/gaussdb-12-0566.html#ZH-CN_TOPIC_0000001911586685),[DROP SERVER](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/devg-dist/gaussdb-12-0617.html#ZH-CN_TOPIC_0000001865585888)

更多详情请参考GaussDB 文档中心:<https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/productdesc/qlh_03_0001.html>