用慣了MySQL後,想嘗試使用下PostgreSQL,據說這玩意兒也很強大,我在網上搜索了下相關中文書籍,可惜相關書籍遠遠沒有MySQL那麼多,不過我在官方找到了由志願者翻譯的文檔(參考9.1文檔翻譯項目),說實話我英文文檔閱讀能力還是比較糾結的,所以有中文文檔當然優先中文了。
在Debian下可以通過apt-get命令直接安裝:
復制代碼 代碼如下:
sudo apt-get install postgresql postgresql-client postgresql-server-dev-all
安裝完成後,PostgreSQL默認就創建了名為postgres用戶,這個和MySQL的root以及SQL Server的sa賬戶一樣,是超級管理員賬戶,與MySQL不一樣的是,其還創建了postgres的Unix系統賬戶,和SQL Server的master數據庫一樣,PostgreSQL的默認數據庫是template1,你可以用命令行管理工具psql來管理它,當然前提是要切換到postgres的系統賬戶:
復制代碼 代碼如下:
# su - postgres
$ psql
或者你可以通過sudo來一步到位的以postgres身份運行psql,省得切換來切換去:
復制代碼 代碼如下:sudo su postgres -c psql template1
完成上述命令後你就應該可以看到操作數據庫的命令界面了,注意\q是退出命令,每句SQL語句以英文分號結束。如果要連接指定的數據庫請使用形如\c databasename的命令。
好,讓我們輸入\q先退出這個命令界面,接下來我們需要創建一個普通賬戶,因為建議不直接用超級管理員postgres賬戶來操作我們自己的數據庫。
首先創建名為mypguser的系統賬戶。
復制代碼 代碼如下:sudo adduser mypguser
其次使用postgres連接template1並進入psql命令界面:
復制代碼 代碼如下:sudo su postgres -c psql template1
創建新的數據庫用戶、新數據庫,並賦予新用戶新數據庫的全部權限:
復制代碼 代碼如下:postgres=# CREATE USER mypguser WITH PASSWORD 'mypguserpass';
postgres=# CREATE DATABASE mypgdatabase;
postgres=# GRANT ALL PRIVILEGES ON DATABASE mypgdatabase to mypguser;
當然上述的操作可以分別以shell命令createuser mypguser以及createdb mypgdatabase來實現:
復制代碼 代碼如下:
# createuser mypguser #from regular shell
# su - mypguser
$ psql postgres
postgres=# CREATE DATABASE mypgdatabase;
完成這些後讓我們使用\q命令退出psql控制台。
復制代碼 代碼如下:postgres=# \q
下面我們就可以用指定賬戶管理我們的數據庫了:
復制代碼 代碼如下:
sudo su mypguser -c 'psql -d mypgdatabase'
等等,我們還有最重要的一步就是重置我們的postgres賬戶密碼,通過下面的命令:
復制代碼 代碼如下:
sudo su postgres -c psql template1
template1=# ALTER USER postgres WITH PASSWORD 'yourpassword'
template1=# \q
不要忘了還有系統賬戶的密碼:
復制代碼 代碼如下:sudo passwd -d postgres
好了,到這裡簡單的安裝及創建賬戶已經講解完畢了,介紹一下可能的錯誤:
如果出現下面的錯誤:
復制代碼 代碼如下:
psql: FATAL: Ident authentication failed for user "mypguser"
請編輯你的pg_hba.conf,這個文件一般位於/etc/postgresql/X.Y/main/pg_hba.conf,X.Y是你的PostgreSQL的版本號,將下面行的peer改為trust:
復制代碼 代碼如下:local all all trust # replace ident or peer with trust
如果出現下面的錯誤:
復制代碼 代碼如下:
psql: FATAL: Peer authentication failed for user "mypguser"
請仍然修改pg_hba.conf文件,該下面行的peer為md5:
復制代碼 代碼如下:local all all md5 # replace peer with md5
完成上面的修改後請重新加載postgresql:
復制代碼 代碼如下:
/etc/init.d/postgresql reload