openGauss的SCHEMA的原理及管理介绍(opencha是什么意思)没想到

随心笔谈2年前发布 admin
230 0 0

文章摘要

这篇文章介绍了openGauss数据库中的Schema管理原理及其操作,重点阐述了Schema的定义、创建、修改、删除以及用户权限管理的相关语法和案例。 Schema是数据库中的模式,用于组织和管理数据库对象。通过管理Schema,可以允许多个用户共享同一数据库而不产生冲突。文章详细说明了以下操作: 1. **Schema语法**:包括创建、修改和删除Schema的命令,例如: - `CREATE SCHEMA`:用于创建Schema。 - `ALTER SCHEMA`:用于修改和删除Schema。 - `DROP SCHEMA`:用于删除Schema。 2. **用户权限管理**:通过指定AUTHORIZATION参数为Schema赋予用户权限,例如: - `CREATE USER`并指定`AUTHORIZATION`给特定用户。 - 授予用户创建、删除和修改对象的权限。 3. **案例分析**:展示了如何创建、修改和删除Schema,以及如何管理用户权限,如: - 创建Schema `tpcds`。 - 修改Schema名称和修改者。 - 授予用户`jeames`对Schema `tpcds1`的访问权限。 - 创建并操作Schema下的表结构。 文章还特别提醒用户注意,不要随意删除系统Schema(如`pg_temp`和`pg_toast_temp`开头的Schema),这些Schema是系统内部使用的。 通过这篇文章,读者可以掌握openGauss中Schema的创建、管理及权限控制的基本方法,为实际应用提供参考。



目录 1.何为Schema摘要: 2.Schema语法? 2.1 创建SCHEMA? 2.2 修改SCHEMA? 2.3 删除SCHEMA 3.Schema赋权

本篇介绍了openGauss的SCHEMA的原理及管理。

Schema又称作模式。通过管理Schema,允许多个用户使用同一数据库而不相互干扰,可以将数据库对象组织成易于管理的逻辑组,同时便于将第三方应用添加到相应的Schema下而不引起冲突。

数据库(database)、用户(user)、schema、和表的关系如下图所示:

每个数据库包含一个或多个Schema。数据库中的每个Schema包含表和其他类型的对象。数据库创建初始,默认具有一个名为public的Schema,且所有用户都拥有此Schema的usage权限,只有系统管理员和初始化用户可以在public Schema下创建函数、存储过程和同义词对象,其他用户即使赋予create权限后也不可以创建上述三种对象。可以通过Schema分组数据库对象。Schema类似于操作系统目录,但Schema不能嵌套。

注意要点

相同的数据库对象名称可以应用在同一数据库的不同Schema中 CREATE USER创建用户的同时,系统会在执行该命令的数据库中,为该用户创建一个同名的SCHEMA 可以把schema理解成操作系统的目录(文件夹),所不同的是schema只有一层,不能嵌套创建

语法:CREATE SCHEMA schema_name [ AUTHORIZATION user_name ] ;

案例1:创建一个名为tpcds的模式

openGauss=# create schema tpcds;
openGauss=# \dn+ tpcds
List of schemas
Name | Owner | Access privileges | Description | WithBlockChain
——-+——-+——————-+————-+—————-
tpcds | omm | | | f

修改模式的名称语法:ALTER SCHEMA schema_name RENAME TO new_name; 修改模式的所有者语法:ALTER SCHEMA schema_name OWNER TO new_owner;

案例1:重命名tpcds为tpcds1

openGauss=# ALTER SCHEMA tpcds RENAME TO tpcds1;
ALTER SCHEMA
openGauss=# \dn+ tpcds1
List of schemas
Name | Owner | Access privileges | Description | WithBlockChain
——–+——-+——————-+————-+—————-
tpcds1 | omm | | | f

案例2:创建一个用户jeames, 并将tpcds1的owner修改为jeames

openGauss=# CREATE USER jeames PASSWORD ‘abcd@123’;
CREATE ROLE
openGauss=# \dn
List of schemas
Name | Owner
—————–+——–
blockchain | omm
cstore | omm
db4ai | omm
dbe_perf | omm
dbe_pldebugger | omm
dbe_pldeveloper | omm
jeames | jeames
mesdb | mesdb
pkg_service | omm
public | omm
snapshot | omm
sqladvisor | omm
tpcds1 | omm
(13 rows)
openGauss=# ALTER SCHEMA tpcds1 OWNER TO jeames;
ALTER SCHEMA
openGauss=# \dn+ tpcds1
List of schemas
Name | Owner | Access privileges | Description | WithBlockChain
——–+——–+——————-+————-+—————-
tpcds1 | jeames | | | f

案例3:在模式tpcds1中建表customer、插入记录和查询记录 

openGauss=# create table tpcds1.customer(id int, name char(30));
CREATE TABLE
openGauss=# insert into tpcds1.customer values(1 ,’xxxx’);
INSERT 0 1
openGauss=# select * from tpcds1.customer;
id | name
—-+——————————–
1 | xxxx

语法:DROP SCHEMA schema_name; 注:不要随意删除pg_temp或pg_toast_temp开头的模式,这些模式是系统内部使用的

DROP SCHEMA tpcds1 CASCADE;

补充

要查看属于某Schema下的表列表,请查询系统视图PG_TABLES: openGauss=# SELECT distinct(tablename),schemaname from pg_tables where schemaname=’pg_catalog’;

普通schema的create权限grant给其他用户后,其他用户即可以创建对象。

分别创建schema teacher_zhao2、teacher_zhao3(指定AUTHORIZATION),并把create权限赋给teacher_li:
openGauss=# create SCHEMA teacher_zhao2;
CREATE SCHEMA
openGauss=# \dn+ teacher_zhao2
List of schemas
Name | Owner | Access privileges | Description | WithBlockChain
—————+——-+——————-+————-+—————-
teacher_zhao2 | omm | | | f
openGauss=# CREATE SCHEMA teacher_zhao3 AUTHORIZATION jeames;
CREATE SCHEMA
openGauss=# \dn+ teacher_zhao3
List of schemas
Name | Owner | Access privileges | Description | WithBlockChain
—————+——–+——————-+————-+—————-
teacher_zhao3 | jeames | | | f
可以发现没有指定AUTHORIZATION的情况下,默认创建用户是clouduser(系统管理员),
而指定情况下,则创建用户就是指定的用户。

下面尝试用jeames登录,创建数据库对象teacher_zhao2.t2:

openGauss=# grant create on SCHEMA teacher_zhao2 to jeames;
openGauss=# grant all on all tables in schema teacher_zhao2 to jeames;
openGauss=# grant select on teacher_zhao2.t2 to jeames;
openGauss=> create table teacher_zhao2.t2(a int);
openGauss=# \c postgres jeames
openGauss=> create table teacher_zhao2.t2(a int);

以上就是openGauss的SCHEMA的原理及管理介绍的详细内容,更多关于openGauss SCHEMA管理的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:windows环境下python连接openGauss数据库的全过程教你使用Psycopg2连接openGauss的方法Linux环境下的Java(JDBC)连接openGauss数据库实践记录Monaco-editor 的 JSON Schema 配置及使用介绍JSON schema配置规范使用教程JSON?Schema概念及使用场景

© 版权声明

相关文章