PostgreSQL新手入門_第1頁
PostgreSQL新手入門_第2頁
PostgreSQL新手入門_第3頁
PostgreSQL新手入門_第4頁
PostgreSQL新手入門_第5頁
已閱讀5頁,還剩8頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、作者:阮一峰 日期:2013年12月22日 自從MySQL被Oracle收購以后,PostgreSQL逐漸成為開源關(guān) 系型數(shù)據(jù)庫的首選。本文介紹PostgreSQL的安裝和基本用法,供初次使用者上手。以下內(nèi)容基于Debian操作系統(tǒng),其他操作系統(tǒng)實在沒有精力兼顧,但是大部分內(nèi)容應(yīng)該普遍適用。PostgreSQL、安裝 首先,安裝 PostgreSQL客戶端。sudo apt-get in stall postgresql-clie nt然后,安裝PostgreSQL服務(wù)器。sudo apt-get in stall postgresql正常情況下,安裝完成后,PostgreSQL服務(wù)器會自動在

2、本機(jī)的5432端口開啟。如果還想安裝圖形管理界面,可以運(yùn)行下面命令,但是本文不涉及這方面內(nèi)容。sudo apt-get in stall pgadm in3二、添加新用戶和新數(shù)據(jù)庫初次安裝后,默認(rèn)生成一個名為postgres的數(shù)據(jù)庫和一個名為postgres的數(shù)據(jù)庫用戶。這里需要注意的是,同時還生成了一個 名為postgres的Linux系統(tǒng)用戶。下面,我們使用postgres用戶,來生成其他用戶和新數(shù)據(jù)庫。好 幾種方法可以達(dá)到這個目的,這里介紹兩種。第一種方法,使用 PostgreSQL控制臺。首先,新建一個Linux新用戶,可以取你想要的名字,這里為dbuser。sudo adduser

3、dbuser然后,切換到postgres用戶。sudo su - postgres下一步,使用psql命令登錄PostgreSQL控制臺。psql這時相當(dāng)于系統(tǒng)用戶 postgres以同名數(shù)據(jù)庫用戶的身份,登錄數(shù)據(jù)庫,這是不用輸入密碼的。如果一切正常,系統(tǒng)提示符會變?yōu)?"postgres=#",表示這時已經(jīng)進(jìn)入了數(shù)據(jù)庫控制臺。以下的命令 都在控制臺內(nèi)完成。第一件事是使用'password命令,為postgres用戶設(shè)置一個密碼。'password postgres第二件事是創(chuàng)建數(shù)據(jù)庫用戶dbuser(剛才創(chuàng)建的是Linux系統(tǒng)用戶),并設(shè)置密碼。CREATE

4、 USER dbuser WITH PASSWORD 'password'第三件事是創(chuàng)建用戶數(shù)據(jù)庫,這里為exampledb,并指定所有者為 dbuser。CREATE DATABASE exampledb OWNER dbuser;第四件事是將exampledb數(shù)據(jù)庫的所有權(quán)限都賦予dbuser,否則dbuser只能登錄控制臺,沒有任何數(shù)據(jù)庫操作權(quán)限。GRANT ALL PRIVILEGES ON DATABASE exampledb to dbuser;最后,使用q命令退出控制臺(也可以直接按ctrl+D )。q第二種方法,使用shell命令行。添加新用戶和新數(shù)據(jù)庫,除了在

5、 PostgreSQL控制臺內(nèi),還可以 在shell命令行下完成。這是因為PostgreSQL提供了命令行程序 createuser和createdb。還是以新建用戶 dbuser和數(shù)據(jù)庫 exampledb 為例。首先,創(chuàng)建數(shù)據(jù)庫用戶dbuser,并指定其為超級用戶。sudo -u postgres createuser -superuser dbuser然后,登錄數(shù)據(jù)庫控制臺,設(shè)置dbuser用戶的密碼,完成后退出控制臺。sudo -u postgres psqlpassword dbuserq接著,在shell命令行下,創(chuàng)建數(shù)據(jù)庫 exampledb,并指定所有 者為 dbuser。su

6、do -u postgres createdb -O dbuser exampledb三、登錄數(shù)據(jù)庫添加新用戶和新數(shù)據(jù)庫以后,就要以新用戶的名義登錄數(shù)據(jù)庫, 這時使用的是psql命令。psql -U dbuser -d exampledb -h 127.0.0.1 -p 5432上面命令的參數(shù)含義如下:-U指定用戶,-d指定數(shù)據(jù)庫,-h指 定服務(wù)器,-p指定端口。輸入上面命令以后,系統(tǒng)會提示輸入dbuser用戶的密碼。輸入正確,就可以登錄控制臺了。psql命令存在簡寫形式。如果當(dāng)前Linux系統(tǒng)用戶,同時也是PostgreSQL用戶,則可以省略用戶名(-U參數(shù)的部分)。舉例 來說,我的Linu

7、x系統(tǒng)用戶名為ruanyf,且PostgreSQL數(shù)據(jù)庫 存在同名用戶,則我以ruanyf身份登錄Linux系統(tǒng)后,可以直接 使用下面的命令登錄數(shù)據(jù)庫,且不需要密碼。psql exampledb此時,如果PostgreSQL內(nèi)部還存在與當(dāng)前系統(tǒng)用戶同名的數(shù)據(jù) 庫,貝燧數(shù)據(jù)庫名都可以省略。比如,假定存在一個叫做rua nyf的數(shù)據(jù)庫,則直接鍵入 psql就可以登錄該數(shù)據(jù)庫。psql另外,如果要恢復(fù)外部數(shù)據(jù),可以使用下面的命令。psql exampledb < exampledb.sql四、控制臺命令除了前面已經(jīng)用到的password命令(設(shè)置密碼)和q命令(退 出)以外,控制臺還提供一系列

8、其他命令。h :查看SQL命令的解釋,比如h select 。?:查看psql命令列表。1 :列出所有數(shù)據(jù)庫。c database_name:連接其他數(shù)據(jù)庫。d :列出當(dāng)前數(shù)據(jù)庫的所有表格。d table_name:列出某一張表格的結(jié)構(gòu)。du :列出所有用戶。e :打開文本編輯器。conninfo:列出當(dāng)前數(shù)據(jù)庫和連接的信息。五、數(shù)據(jù)庫操作基本的數(shù)據(jù)庫操作,就是使用一般的SQL語言。#創(chuàng)建新表CREATE TABLE user_tbl( name VARCHAR(20),sig nu p_date DATE);#插入數(shù)據(jù)INSERT INTO user_tbl( name, sig nup_d

9、ate) VALUES(' 張三','2013-12-22');#選擇記錄SELECT * FROM user_tbl;#更新數(shù)據(jù)李四'WHERE name ='UPDATE user_tbl set name =張三';#刪除記錄DELETE FROM user_tbl WHERE name =' 李四'#添加欄位ALTER TABLE user_tbl ADD email VARCHAR(40);#更新結(jié)構(gòu)ALTER TABLE user_tbl ALTER COLUMN sig nu p_date SETNOT NULL;#更名欄位ALTER TABLE user_tbl RENAME COLUMN sig nu p_dat

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論