欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

openGauss的SCHEMA的原理及管理介紹

 更新時(shí)間:2023年02月13日 16:09:47   作者:IT邦德  
這篇文章主要為大家介紹了openGauss的SCHEMA的原理及管理分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

?? 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)文章!

相關(guān)文章

  • Navicat運(yùn)行sql文件導(dǎo)入數(shù)據(jù)不全或?qū)胧〉慕鉀Q方案

    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-03
  • 圖文詳解HTTP頭中的SQL注入

    圖文詳解HTTP頭中的SQL注入

    HTTP頭字段是超文本傳輸協(xié)議(HTTP)中請(qǐng)求和響應(yīng)的部分信息,它們定義了HTTP傳輸?shù)牟僮鲄?shù),下面這篇文章主要給大家介紹了關(guān)于HTTP頭中SQL注入的相關(guān)資料,需要的朋友可以參考下
    2021-12-12
  • Doris?數(shù)據(jù)模型ROLLUP及前綴索引官方教程

    Doris?數(shù)據(jù)模型ROLLUP及前綴索引官方教程

    本文檔主要從邏輯層面,描述 Doris 的數(shù)據(jù)模型 ROLLUP 以及前綴索引的概念,以幫助用戶更好的使用 Doris 應(yīng)對(duì)不同的業(yè)務(wù)場(chǎng)景,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • 交叉表查詢sql語句

    交叉表查詢sql語句

    交叉表查詢sql語句...
    2007-06-06
  • dba_indexes視圖的性能分析

    dba_indexes視圖的性能分析

    前端時(shí)間,在監(jiān)控系統(tǒng)中加入了index的狀態(tài)是否為unusable,以及其并行度是否有設(shè)置的監(jiān)控:
    2008-08-08
  • 通過navicat導(dǎo)入sql文件的操作方法

    通過navicat導(dǎo)入sql文件的操作方法

    在很多項(xiàng)目當(dāng)中都有sql文件導(dǎo)入到MySQL數(shù)據(jù)庫的需要,因?yàn)橛衧ql數(shù)據(jù)庫文件,這個(gè)項(xiàng)目才能正常運(yùn)行起來,那么現(xiàn)在就來學(xué)習(xí)一下怎么導(dǎo)入sql文件到navicat里面吧,需要的朋友可以參考下
    2024-03-03
  • SQL 按特定字段值排序

    SQL 按特定字段值排序

    SQL 按特定字段值排序的代碼,有需要的朋友可以參考下。
    2009-08-08
  • DeepinV20快速安裝Mariadb的詳細(xì)步驟

    DeepinV20快速安裝Mariadb的詳細(xì)步驟

    本文給大家介紹DeepinV20安裝Mariadb的詳細(xì)步驟,MariaDB數(shù)據(jù)庫管理系統(tǒng)是MySQL的一個(gè)分支,添加一些功能支持本地的非阻塞操作和進(jìn)度報(bào)告,具體內(nèi)容詳情跟隨小編一起看看吧
    2021-07-07
  • 詳解SQLite中的查詢規(guī)劃器

    詳解SQLite中的查詢規(guī)劃器

    這篇文章主要介紹了詳解SQLite中的查詢規(guī)劃器,SQLite是一個(gè)開源的嵌入式數(shù)據(jù)庫,需要的朋友可以參考下
    2015-07-07
  • 在windows系統(tǒng)下如何安裝memcached的講解

    在windows系統(tǒng)下如何安裝memcached的講解

    今天小編就為大家分享一篇關(guān)于在windows系統(tǒng)下如何安裝memcached的講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03

最新評(píng)論