1.4. 存取一個資料庫

一旦你已經建立一個資料庫,你就可以開始以下列方式進行存取:

  • 執行 PostgreSQL 互動式的終端程式,稱作 psql,它可以讓你輸入、編輯、執行 SQL 指令。
  • 使用既有的圖型化介面工具,例如 pgAdmin 或是支援 ODBC 或 JDBC 的辦公室軟體,以建立並輸入資料到資料庫裡。不過這部份並未包含在這份手冊之中。
  • 自行撰寫一個程式,可以使用許多種程式語言來完成。這個部份將會在第 IV 章中進行介紹。

在這份指南中,你可能會先使用 psql 來進行一些嘗試。你可以藉由下列指令開始操作 mydb 這個資料庫:

  1. $ psql mydb

如果你並未指明資料庫名稱,那麼它預設會以你的使用者名稱作為資料庫名稱。在先前的章節使用 createdb 時,你已經知道這個隱含的規則了。

在 psql 中,你會以下列訊息開始:

  1. psql (10beta1)
  2. Type "help" for help.
  3. mydb=>

最後一行也可能是:

  1. mydb=#

這表示你是資料庫的超級使用者(superuser),如果你是自行安裝 PostgreSQL 的話,大概就會是這個情況。
作為一個超級使用者,表示你不會受限於任何存取控制。不過在這份指南中,這並不是重要的事。

如果你在啓動 psql 時遭遇了一些問題,那麼請回到前一節。createdb 和 psql 的行為很類似,如果前者正常,後者也應該如期運行。

最後一行會輸出的是 psql 的提示字串,它表示 psql 正在等待你輸入 SQL 查詢語句。試試下面的指令吧:

  1. mydb=> SELECT version();
  2. version
  3. ------------------------------------------------------------------------------------------
  4. PostgreSQL 10beta1 on x86_64-pc-linux-gnu, compiled by gcc (Debian 4.9.2-10) 4.9.2, 64-bit
  5. (1 row)
  6. mydb=> SELECT current_date;
  7. date
  8. ------------
  9. 2016-01-07
  10. (1 row)
  11. mydb=> SELECT 2 + 2;
  12. ?column?
  13. ----------
  14. 4
  15. (1 row)

psql 程式中也內建了一些非 SQL 的命令。他們會以倒斜線( )起頭。舉例來說,你可以輸入下列指令以取得一些有關 PostgreSQL 所支援的 SQL 語法資訊:

  1. mydb=> \h

要離開 psql 的話,請輸入:

  1. mydb=> \q

如此的話,psql 將會結束,並回到你的命令列介面之中。(想瞭解更多內建指令,在 psql 提示字串後輸入 \? 。)完整的 psql 說明,都記載在 psql 頁面之中。在這份指南中,我們並未使用這些功能,但你可以在需要的時候使用他們。