麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數(shù)據(jù)庫 > PostgreSQL > 正文

PostgreSQL教程(二):模式Schema詳解

2020-01-31 15:22:51
字體:
來源:轉載
供稿:網(wǎng)友

一個數(shù)據(jù)庫包含一個或多個命名的模式,模式又包含表。模式還包含其它命名的對象,包括數(shù)據(jù)類型、函數(shù),以及操作符。同一個對象名可以在不同的模式里使用而不會導致沖突; 比如,schema1和myschema都可以包含叫做mytable的表。和數(shù)據(jù)庫不同,模式不是嚴格分離的:一個用戶可以訪問他所連接的數(shù)據(jù)庫中的任意模式中的對象,只要他有權限。

    我們需要模式有以下幾個主要原因:

    1). 允許多個用戶使用一個數(shù)據(jù)庫而不會干擾其它用戶。
    2). 把數(shù)據(jù)庫對象組織成邏輯組,讓它們更便于管理。
    3). 第三方的應用可以放在不同的模式中,這樣它們就不會和其它對象的名字沖突。
    
    1. 創(chuàng)建模式:
 

復制代碼 代碼如下:

    CREATE SCHEMA myschema;
 

    通過以上命令可以創(chuàng)建名字為myschema的模式,在該模式被創(chuàng)建后,其便可擁有自己的一組邏輯對象,如表、視圖和函數(shù)等。
    
    2. public模式:

    在介紹后面的內容之前,這里我們需要先解釋一下public模式。每當我們創(chuàng)建一個新的數(shù)據(jù)庫時,PostgreSQL都會為我們自動創(chuàng)建該模式。當?shù)卿浀皆摂?shù)據(jù)庫時,如果沒有特殊的指定,我們將以該模式(public)的形式操作各種數(shù)據(jù)對象,如:
 

復制代碼 代碼如下:

    CREATE TABLE products ( ... ) 等同于 CREATE TABLE public.products ( ... )
   

    3. 權限:
    缺省時,用戶看不到模式中不屬于他們所有的對象。為了讓他們看得見,模式的所有者需要在模式上賦予USAGE權限。為了讓用戶使用模式中的對象,我們可能需要賦予額外的權限,只要是適合該對象的。PostgreSQL根據(jù)不同的對象提供了不同的權限類型,如:
 
復制代碼 代碼如下:

    GRANT ALL ON SCHEMA myschema TO public;
 

    上面的ALL關鍵字將包含CREATE和USAGE兩種權限。如果public模式擁有了myschema模式的CREATE權限,那么登錄到該模式的用戶將可以在myschema模式中創(chuàng)建任意對象,如:
 
復制代碼 代碼如下:

    CREATE TABLE myschema.products (
        product_no integer,
        name text,
        price numeric CHECK (price > 0),
    );
 

    在為模式下的所有表賦予權限時,需要將權限拆分為各種不同的表操作,如:
 
復制代碼 代碼如下:

    ALTER DEFAULT PRIVILEGES IN SCHEMA myschema
    GRANT INSERT, SELECT, UPDATE, DELETE, TRUNCATE, REFERENCES, TRIGGER ON TABLES TO public;
 

    在為模式下的所有Sequence序列對象賦予權限時,需要將權限拆分為各種不同的Sequence操作,如:
 
復制代碼 代碼如下:

    ALTER DEFAULT PRIVILEGES IN SCHEMA myschema
    GRANT SELECT, UPDATE, USAGE ON SEQUENCES TO public;
 

    在為模式下的所有函數(shù)賦予權限時,僅考慮執(zhí)行權限,如:
 
復制代碼 代碼如下:

    ALTER DEFAULT PRIVILEGES IN SCHEMA myschema
    GRANT EXECUTE ON FUNCTIONS TO public;
 

    可以看出,通過以上方式在public模式下為myschema模式創(chuàng)建各種對象是極為不方便的。下面我們將要介紹另外一種方式,即通過role對象,直接登錄并關聯(lián)到myschema對象,之后便可以在myschema模式下直接創(chuàng)建各種所需的對象了。
   
復制代碼 代碼如下:

    CREATE ROLE myschema LOGIN PASSWORD '123456'; --創(chuàng)建了和該模式關聯(lián)的角色對象。
    CREATE SCHEMA myschema AUTHORIZATION myschema; --將該模式關聯(lián)到指定的角色,模式名和角色名可以不相等。
 

    在Linux Shell下,以myschema的角色登錄到數(shù)據(jù)庫MyTest,在密碼輸入正確后將成功登錄到該數(shù)據(jù)庫。
 
復制代碼 代碼如下:

    /> psql -d MyTest -U myschema
    Password:
    MyTest=> CREATE TABLE test(i integer);
    CREATE TABLE
    MyTest=> /d   --查看該模式下,以及該模式有權限看到的tables信息列表。
              List of relations
     Schema     |   Name   | Type  |  Owner
    ------------+---------+------+----------
     myschema |   test     | table  | myschema
    (1 rows)
   

    4. 刪除模式:
 
復制代碼 代碼如下:

    DROP SCHEMA myschema;
 

    如果要刪除模式及其所有對象,請使用級聯(lián)刪除:
 
復制代碼 代碼如下:

    DROP SCHEMA myschema CASCADE;
 

    
    5. 模式搜索路徑:

    我們在使用一個數(shù)據(jù)庫對象時可以使用它的全稱來定位對象,然而這樣做往往也是非常繁瑣的,每次都不得不鍵入owner_name.object_name。PostgreSQL中提供了模式搜索路徑,這有些類似于Linux中的$PATH環(huán)境變量,當我們執(zhí)行一個Shell命令時,只有該命令位于$PATH的目錄列表中,我們才可以通過命令名直接執(zhí)行,否則就需要輸入它的全路徑名。PostgreSQL同樣也通過查找一個搜索路徑來判斷一個表究竟是哪個表,這個路徑是一個需要查找的模式列表。在搜索路徑里找到的第一個表將被當作選定的表。如果在搜索路徑中 沒有匹配表,那么就報告一個錯誤,即使匹配表的名字在數(shù)據(jù)庫其它的模式中存在也如此。
    在搜索路徑中的第一個模式叫做當前模式。除了是搜索的第一個模式之外,它還是在CREATE TABLE沒有聲明模式名的時候,新建表所屬于的模式。要顯示當前搜索路徑,使用下面的命令:
 

復制代碼 代碼如下:

    MyTest=> SHOW search_path;
      search_path
    ----------------
     "$user",public
    (1 row)
 

    可以將新模式加入到搜索路徑中,如:
 
復制代碼 代碼如下:

    SET search_path TO myschema,public;
 

    為搜索路徑設置指定的模式,如:
 
復制代碼 代碼如下:

    SET search_path TO myschema; --當前搜索路徑中將只是包含myschema一種模式。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 91精品国产综合久久婷婷香 | 国产精品a一 | 欧美成人精品一区二区男人小说 | 亚洲午夜天堂吃瓜在线 | 999久久久久久 | 黄色的视频在线观看 | 国产精品视频一区二区三区四区五区 | 成年人在线视频观看 | 欧美成人精品一区二区三区 | 羞羞电影网 | 成人三级视频在线观看 | japan护士性xxxⅹhd | 麻豆自拍偷拍视频 | 久久凹凸 | 羞羞网站| 性欧美极品xxxx欧美一区二区 | 亚洲国产色婷婷 | 午夜视频在线观看免费视频 | 免费在线看a | 2019中文字幕在线播放 | 黄网站免费观看视频 | 1区2区3区国产 | www.91操 | 国产羞羞视频在线免费观看 | 久久久国产精品网站 | 成人福利在线免费观看 | 国内精品伊人久久 | h色网站免费观看 | 鲁人人人鲁人人鲁精品 | 成人免费看视频 | 精品国产96亚洲一区二区三区 | 激情小视频在线观看 | 欧美综合在线观看 | 99精品国产在热久久婷婷 | 性少妇chinesevideo | 一级一级一级一级毛片 | 天堂亚洲一区 | 欧美日韩在线视频一区 | 国产成人精品一区二区视频免费 | 91久久国产| 嫩草影院在线观看网站成人 |