openGauss的SCHEMA的原理及管理介紹
?? 1.何為Schema摘要:
本篇介紹了openGauss的SCHEMA的原理及管理。
Schema又稱作模式。通過管理Schema,允許多個(gè)用戶使用同一數(shù)據(jù)庫而不相互干擾,可以將數(shù)據(jù)庫對(duì)象組織成易于管理的邏輯組,同時(shí)便于將第三方應(yīng)用添加到相應(yīng)的Schema下而不引起沖突。
?????? 數(shù)據(jù)庫(database)、用戶(user)、schema、和表的關(guān)系如下圖所示:
每個(gè)數(shù)據(jù)庫包含一個(gè)或多個(gè)Schema。數(shù)據(jù)庫中的每個(gè)Schema包含表和其他類型的對(duì)象。數(shù)據(jù)庫創(chuàng)建初始,默認(rèn)具有一個(gè)名為public的Schema,且所有用戶都擁有此Schema的usage權(quán)限,只有系統(tǒng)管理員和初始化用戶可以在public Schema下創(chuàng)建函數(shù)、存儲(chǔ)過程和同義詞對(duì)象,其他用戶即使賦予create權(quán)限后也不可以創(chuàng)建上述三種對(duì)象。可以通過Schema分組數(shù)據(jù)庫對(duì)象。Schema類似于操作系統(tǒng)目錄,但Schema不能嵌套。
??????注意要點(diǎn)
相同的數(shù)據(jù)庫對(duì)象名稱可以應(yīng)用在同一數(shù)據(jù)庫的不同Schema中 CREATE USER創(chuàng)建用戶的同時(shí),系統(tǒng)會(huì)在執(zhí)行該命令的數(shù)據(jù)庫中,為該用戶創(chuàng)建一個(gè)同名的SCHEMA 可以把schema理解成操作系統(tǒng)的目錄(文件夾),所不同的是schema只有一層,不能嵌套創(chuàng)建
?? 2.Schema語法
? 2.1 創(chuàng)建SCHEMA
語法:CREATE SCHEMA schema_name [ AUTHORIZATION user_name ] ;
案例1:創(chuàng)建一個(gè)名為tpcds的模式
openGauss=# create schema tpcds; openGauss=# \dn+ tpcds List of schemas Name | Owner | Access privileges | Description | WithBlockChain -------+-------+-------------------+-------------+---------------- tpcds | omm | | | f
? 2.2 修改SCHEMA
修改模式的名稱語法: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:創(chuàng)建一個(gè)用戶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
? 2.3 刪除SCHEMA
語法:DROP SCHEMA schema_name; 注:不要隨意刪除pg_temp或pg_toast_temp開頭的模式,這些模式是系統(tǒng)內(nèi)部使用的
DROP SCHEMA tpcds1 CASCADE;
?????? 補(bǔ)充
要查看屬于某Schema下的表列表,請(qǐng)查詢系統(tǒng)視圖PG_TABLES: openGauss=# SELECT distinct(tablename),schemaname from pg_tables where schemaname = 'pg_catalog';
?? 3.Schema賦權(quán)
普通schema的create權(quán)限grant給其他用戶后,其他用戶即可以創(chuàng)建對(duì)象。
分別創(chuàng)建schema teacher_zhao2、teacher_zhao3(指定AUTHORIZATION),并把create權(quán)限賦給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 可以發(fā)現(xiàn)沒有指定AUTHORIZATION的情況下,默認(rèn)創(chuàng)建用戶是clouduser(系統(tǒng)管理員), 而指定情況下,則創(chuàng)建用戶就是指定的用戶。
下面嘗試用jeames登錄,創(chuàng)建數(shù)據(jù)庫對(duì)象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的原理及管理介紹的詳細(xì)內(nèi)容,更多關(guān)于openGauss SCHEMA管理的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- openGauss數(shù)據(jù)庫共享存儲(chǔ)特性概述
- Navicat Premium遠(yuǎn)程連接MySQL數(shù)據(jù)庫的方法
- 解決navicat遠(yuǎn)程連接mysql報(bào)錯(cuò)10038的問題
- 詳解Navicat遠(yuǎn)程連接mysql很慢
- 解決Navicat遠(yuǎn)程連接MySQL出現(xiàn) 10060 unknow error的方法
- Navicat 遠(yuǎn)程連接 MySQL實(shí)現(xiàn)步驟解析
- 詳解使用navicat連接遠(yuǎn)程linux mysql數(shù)據(jù)庫出現(xiàn)10061未知故障
- 如何使用navicat遠(yuǎn)程連接openGauss
相關(guān)文章
Navicat運(yùn)行sql文件導(dǎo)入數(shù)據(jù)不全或?qū)胧〉慕鉀Q方案
最近導(dǎo)出數(shù)據(jù)庫到另一個(gè)服務(wù)器,遇到這個(gè)問題,下面這篇文章主要給大家介紹了關(guān)于Navicat運(yùn)行sql文件導(dǎo)入數(shù)據(jù)不全或?qū)胧〉慕鉀Q方案,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03Doris?數(shù)據(jù)模型ROLLUP及前綴索引官方教程
本文檔主要從邏輯層面,描述 Doris 的數(shù)據(jù)模型 ROLLUP 以及前綴索引的概念,以幫助用戶更好的使用 Doris 應(yīng)對(duì)不同的業(yè)務(wù)場(chǎng)景,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05在windows系統(tǒng)下如何安裝memcached的講解
今天小編就為大家分享一篇關(guān)于在windows系統(tǒng)下如何安裝memcached的講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-03-03