华为云云数据库GaussDBCREATE SCHEMA_云淘科技
功能描述
创建模式。
访问命名对象时可以使用模式名作为前缀进行访问,如果无模式名前缀,则访问当前模式下的命名对象。创建命名对象时也可用模式名作为前缀修饰。
另外,CREATE SCHEMA可以包括在新模式中创建对象的子命令,这些子命令和那些在创建完模式后发出的命令没有任何区别。如果使用了AUTHORIZATION子句,则所有创建的对象都将被该用户所拥有。
注意事项
只要用户对当前数据库有CREATE权限,就可以创建模式。
系统管理员在普通用户同名schema下创建的对象,所有者为schema的同名用户(非系统管理员)。
语法格式
根据指定的名称创建模式。
1 2 |
CREATE SCHEMA schema_name [ AUTHORIZATION user_name ] [WITH BLOCKCHAIN] [ schema_element [ ... ] ]; |
根据用户名创建模式。
1 |
CREATE SCHEMA AUTHORIZATION user_name [ schema_element [ ... ] ]; |
参数说明
schema_name
模式名称。
模式名不能和当前数据库里其他的模式重名。
模式名不能和当前数据库的初始用户重名。
模式的名称不可以“pg_”开头。
模式的名称不可以“gs_role_”开头。
取值范围:字符串,要符合标识符命名规范。
AUTHORIZATION user_name
指定模式的所有者。当不指定schema_name时,把user_name当作模式名,此时user_name只能是角色名。
取值范围:已存在的用户名/角色名。
WITH BLOCKCHAIN
指定模式的防篡改属性。防篡改模式下的普通行存表为防篡改用户表。
schema_element
在模式里创建对象的SQL语句。目前仅支持CREATE TABLE、CREATE VIEW、CREATE INDEX、CREATE PARTITION、GRANT子句。
子命令所创建的对象都被AUTHORIZATION子句指定的用户所拥有。
如果当前搜索路径上的模式中存在同名对象时,需要明确指定引用对象所在的模式。可以通过命令SHOW SEARCH_PATH来查看当前搜索路径上的模式。
示例
1 2 3 4 5 6 7 8 9 10 11 12 13 |
--创建一个角色role1。 gaussdb=# CREATE ROLE role1 IDENTIFIED BY '********'; -- 为用户role1创建一个同名schema,子命令创建的表films和winners的拥有者为role1。 gaussdb=# CREATE SCHEMA AUTHORIZATION role1 CREATE TABLE films (title text, release date, awards text[]) CREATE VIEW winners AS SELECT title, release FROM films WHERE awards IS NOT NULL; --删除schema。 gaussdb=# DROP SCHEMA role1 CASCADE; --删除用户。 gaussdb=# DROP USER role1 CASCADE; |
相关链接
ALTER SCHEMA,DROP SCHEMA
父主题: SQL语法
同意关联代理商云淘科技,购买华为云产品更优惠(QQ 78315851)
内容没看懂? 不太想学习?想快速解决? 有偿解决: 联系专家