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

來源:互聯網
上載者:User

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

一個資料庫包含一個或多個命名的模式,模式又包含表。模式還包含其它命名的對象,包括資料類型、函數,以及操作符。同一個對象名可以在不同的模式裡使用而不會導致衝突; 比如,schema1和myschema都可以包含叫做mytable的表。和資料庫不同,模式不是嚴格分離的:一個使用者可以訪問他所串連的資料庫中的任意模式中的對象,只要他有許可權。

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

    1). 允許多個使用者使用一個資料庫而不會干擾其它使用者。
    2). 把資料庫物件組織成邏輯組,讓它們更便於管理。
    3). 第三方的應用可以放在不同的模式中,這樣它們就不會和其它對象的名字衝突。
    
    1. 建立模式:
 複製代碼 代碼如下:
    CREATE SCHEMA myschema;
 
    通過以上命令可以建立名字為myschema的模式,在該模式被建立後,其便可擁有自己的一組邏輯對象,如表、視圖和函數等。
    
    2. public模式:

    在介紹後面的內容之前,這裡我們需要先解釋一下public模式。每當我們建立一個新的資料庫時,PostgreSQL都會為我們自動建立該模式。當登入到該資料庫時,如果沒有特殊的指定,我們將以該模式(public)的形式操作各種資料對象,如:
 複製代碼 代碼如下:
    CREATE TABLE products ( ... ) 等同於 CREATE TABLE public.products ( ... )
   
    3. 許可權:
    預設時,使用者看不到模式中不屬於他們所有的對象。為了讓他們看得見,模式的所有者需要在模式上賦予USAGE許可權。為了讓使用者使用模式中的對象,我們可能需要賦予額外的許可權,只要是適合該對象的。PostgreSQL根據不同的對象提供了不同的權限類別型,如:
 複製代碼 代碼如下:
    GRANT ALL ON SCHEMA myschema TO public;
 
    上面的ALL關鍵字將包含CREATE和USAGE兩種許可權。如果public模式擁有了myschema模式的CREATE許可權,那麼登入到該模式的使用者將可以在myschema模式中建立任意對象,如:
 複製代碼 代碼如下:
    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;
 
    在為模式下的所有函數賦予許可權時,僅考慮執行許可權,如:
 複製代碼 代碼如下:
    ALTER DEFAULT PRIVILEGES IN SCHEMA myschema
    GRANT EXECUTE ON FUNCTIONS TO public;
 
    可以看出,通過以上方式在public模式下為myschema模式建立各種對象是極為不方便的。下面我們將要介紹另外一種方式,即通過role對象,直接登入並關聯到myschema對象,之後便可以在myschema模式下直接建立各種所需的對象了。
    複製代碼 代碼如下:
    CREATE ROLE myschema LOGIN PASSWORD '123456'; --建立了和該模式關聯的角色對象。
    CREATE SCHEMA myschema AUTHORIZATION myschema; --將該模式關聯到指定的角色,模式名和角色名稱可以不相等。
 
    在Linux Shell下,以myschema的角色登入到資料庫MyTest,在密碼輸入正確後將成功登入到該資料庫。
 複製代碼 代碼如下:
    /> 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;
 
    如果要刪除模式及其所有對象,請使用串聯刪除:
 複製代碼 代碼如下:
    DROP SCHEMA myschema CASCADE;
 
    
    5. 模式搜尋路徑:

    我們在使用一個資料庫物件時可以使用它的全稱來定位對象,然而這樣做往往也是非常繁瑣的,每次都不得不鍵入owner_name.object_name。PostgreSQL中提供了模式搜尋路徑,這有些類似於Linux中的$PATH環境變數,當我們執行一個Shell命令時,只有該命令位於$PATH的目錄列表中,我們才可以通過命令名直接執行,否則就需要輸入它的全路徑名。PostgreSQL同樣也通過尋找一個搜尋路徑來判斷一個表究竟是哪個表,這個路徑是一個需要尋找的模式列表。在搜尋路徑裡找到的第一個表將被當作選定的表。如果在搜尋路徑中 沒有匹配表,那麼就報告一個錯誤,即使匹配表的名字在資料庫其它的模式中存在也如此。
    在搜尋路徑中的第一個模式叫做當前模式。除了是搜尋的第一個模式之外,它還是在CREATE TABLE沒有聲明模式名的時候,建立表所屬於的模式。要顯示當前搜尋路徑,使用下面的命令:
 複製代碼 代碼如下:
    MyTest=> SHOW search_path;
      search_path
    ----------------
     "$user",public
    (1 row)
 
    可以將新模式加入到搜尋路徑中,如:
 複製代碼 代碼如下:
    SET search_path TO myschema,public;
 
    為搜尋路徑設定指定的模式,如:
 複製代碼 代碼如下:
    SET search_path TO myschema; --當前搜尋路徑中將只是包含myschema一種模式。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.