ฉันใช้ PostgreSQL รุ่นใดอยู่


1026

ฉันอยู่ในสภาพแวดล้อมขององค์กร (ใช้งาน Debian Linux) และไม่ได้ติดตั้งด้วยตนเอง ฉันเข้าถึงฐานข้อมูลโดยใช้ Navicat หรือ phpPgAdmin (หากช่วยได้) ฉันยังไม่มีสิทธิ์เข้าถึงเชลล์ไปยังเซิร์ฟเวอร์ที่รันฐานข้อมูล

คำตอบ:


1645

เรียกใช้แบบสอบถามนี้จาก PostgreSQL:

SELECT version();

4
ไม่มีผลในกรณีของฉันใน terminal บน Ubuntu
Timo

22
@Timo นี่คือแบบสอบถามที่จะเรียกใช้ผ่าน PostgreSQL ซึ่งสามารถทำได้ผ่าน pgAdmin หรือกลไกอื่น ๆ สำหรับการเรียกใช้แบบสอบถาม คุณพยายามเรียกใช้จากเชลล์ของ Ubuntu หรือไม่ (สิ่งนี้จะไม่ทำงาน)
มีความผิดปกติสูงใน

41
นอกจากนี้ยังสามารถเรียกใช้จากบรรทัดคำสั่งด้วยpsql -c 'SELECT version();'
Aaron Lelevier

3
คุณสามารถเรียกใช้โดยตรงจาก bash ที่ระบุ postgres db ดังต่อไปนี้:psql postgres -c 'SELECT version();'
thathashd

22
@ Frank H. ใช้: sudo -u postgres psql postgres -c 'SELECT version()' | grep PostgreSQLควรให้คุณผ่าน "บทบาท" ชื่อผู้ใช้ "ไม่มีอยู่"
Marcus Junius Brutus

550

ฉันเชื่อว่านี่คือสิ่งที่คุณกำลังมองหา

รุ่นเซิร์ฟเวอร์:

pg_config --version

รุ่นลูกค้า:

psql --version

1
ขอบคุณ! ใช้งานได้เมื่อมีการเข้าถึงเชลล์ น่าเสียดายในกรณีของฉันฉันไม่มีสิทธิ์เข้าถึงนั้น ฉันได้อัปเดตคำถามแล้ว
ผิดปกติสูง

3
บางครั้งรุ่นลูกค้าคือสิ่งที่คุณต้องการรู้อยู่แล้ว
Trejkaz

12
ในฐานะที่เป็นแฟรงค์บันทึกสิ่งนี้สามารถหลอกลวง psql จะเชื่อมต่อกับกระบวนการฐานข้อมูล postmaster / postgres ใด ๆ ที่กำลังทำงานอยู่และเอ็นจิ้นฐานข้อมูลอาจไม่เป็นรุ่นเดียวกันกับคำสั่ง psql
Ben Roberts

2
pg_config --versionอาจทำให้เข้าใจผิดเช่นหากคุณอัปเกรดเซิร์ฟเวอร์ Ubuntu และไม่ทำงานpg_upgradeclusterpg_config จะแสดงเวอร์ชันใหม่แทนรุ่นที่คุณยังใช้อยู่
Marius Gedminas

เพียงแค่นี้ใช้งานได้สำหรับฉัน: pg_config --version คำสั่ง: psql --versionไม่ทำงานบ่นสำหรับเรื่องนี้:dyld: Library not loaded: /usr/local/opt/readline/lib/libreadline.7.dylib Referenced from: /usr/local/bin/psql Reason: image not found
rld

217

ใช้ CLI:

รุ่นเซิร์ฟเวอร์:

$ postgres -V  # Or --version.  Use "locate bin/postgres" if not found.
postgres (PostgreSQL) 9.6.1
$ postgres -V | awk '{print $NF}'  # Last column is version.
9.6.1
$ postgres -V | egrep -o '[0-9]{1,}\.[0-9]{1,}'  # Major.Minor version
9.6

หากมีการติดตั้ง PostgreSQL มากกว่าหนึ่งรายการหรือหากได้รับpostgres: command not foundข้อผิดพลาด "":

$ locate bin/postgres | xargs -i xargs -t '{}' -V  # xargs is intentionally twice.
/usr/pgsql-9.3/bin/postgres -V 
postgres (PostgreSQL) 9.3.5
/usr/pgsql-9.6/bin/postgres -V 
postgres (PostgreSQL) 9.6.1

หากlocateไม่ช่วยลองfind:

$ sudo find / -wholename '*/bin/postgres' 2>&- | xargs -i xargs -t '{}' -V  # xargs is intentionally twice.
/usr/pgsql-9.6/bin/postgres -V 
postgres (PostgreSQL) 9.6.1

แม้ว่าจะpostmasterยังสามารถใช้แทนการpostgresใช้postgresเป็นเพราะที่นิยมเป็นนามแฝงของเลิกใช้postmasterpostgres

รุ่นลูกค้า:

ในฐานะที่เกี่ยวข้องเข้าสู่ระบบเป็นpostgres

$ psql -V  # Or --version
psql (PostgreSQL) 9.6.1

หากมีการติดตั้ง PostgreSQL มากกว่าหนึ่งรายการ:

$ locate bin/psql | xargs -i xargs -t '{}' -V  # xargs is intentionally twice.
/usr/bin/psql -V 
psql (PostgreSQL) 9.3.5
/usr/pgsql-9.2/bin/psql -V 
psql (PostgreSQL) 9.2.9
/usr/pgsql-9.3/bin/psql -V 
psql (PostgreSQL) 9.3.5

ใช้ SQL:

รุ่นเซิร์ฟเวอร์:

=> SELECT version();
                                                   version                                                    
--------------------------------------------------------------------------------------------------------------
 PostgreSQL 9.2.9 on x86_64-unknown-linux-gnu, compiled by gcc (GCC) 4.4.7 20120313 (Red Hat 4.4.7-4), 64-bit

=> SHOW server_version;
 server_version 
----------------
 9.2.9

=> SHOW server_version_num;
 server_version_num 
--------------------
 90209

=> SHOW all;ถ้ามีอยากรู้อยากลอง

รุ่นลูกค้า:

สำหรับสิ่งที่คุ้มค่าคำสั่งเชลล์สามารถดำเนินการภายในpsqlเพื่อแสดงเวอร์ชันไคลเอ็นต์ของpsqlไฟล์เรียกทำงานในพา ธ โปรดทราบว่าการทำงานpsqlอาจแตกต่างจากที่อยู่ในเส้นทาง

=> \! psql -V
psql (PostgreSQL) 9.2.9

12
ขอขอบคุณ! ที่เป็นประโยชน์มากในสคริปต์เพื่อหลีกเลี่ยงการแยกในสายยาวของSHOW server_version; SELECT version();
vaab

ขอบคุณมาก. ผู้คนไม่ทราบว่าในการออกคำสั่ง SQL คุณต้องรู้อย่างน้อยหนึ่งบทบาทในการเชื่อมต่อกับฐานข้อมูล แต่ด้วย postgres -V คุณไม่จำเป็นต้องรู้ว่าจะเชื่อมต่อกับฐานข้อมูลเพื่อทราบรุ่นของมัน
ychaouche

หนึ่งบรรทัดใน CLI สมมติเข้าถึง psql postgres -c "SHOW server_version" -t -Asuperuser: -tลบส่วนหัว-Aลบช่องว่างการจัดตำแหน่ง
Pocketsand

ขอบคุณSHOW server_version_numโดยเฉพาะอย่างยิ่งซึ่งมีประโยชน์สำหรับความไม่เท่าเทียมกัน
eswald

63

หากคุณใช้CLIและคุณเป็นpostgres ผู้ใช้คุณสามารถทำสิ่งนี้ได้:

psql -c "SELECT version();"


เอาต์พุตที่เป็น ไปได้:

                                                         version                                                         
-------------------------------------------------------------------------------------------------------------------------
 PostgreSQL 11.1 (Debian 11.1-3.pgdg80+1) on x86_64-pc-linux-gnu, compiled by gcc (Debian 4.9.2-10+deb8u2) 4.9.2, 64-bit
(1 row)

37

คำตอบที่ได้รับการยอมรับนั้นยอดเยี่ยม แต่ถ้าคุณต้องการโต้ตอบโดยทางโปรแกรมกับเวอร์ชัน PostgreSQL อาจเป็นการดีกว่าที่จะทำ:

SELECT current_setting('server_version_num'); -- Returns 90603 (9.6.3)
-- Or using SHOW command:
SHOW server_version_num; -- Returns 90603 too

มันจะส่งคืนเวอร์ชันของเซิร์ฟเวอร์เป็นจำนวนเต็ม นี่คือการทดสอบเวอร์ชันเซิร์ฟเวอร์ในแหล่งข้อมูล PostgreSQLเช่น:

/*
 * This is a C code from pg_dump source.
 * It will do something if PostgreSQL remote version (server) is lower than 9.1.0
 */
if (fout->remoteVersion < 90100)
    /*
     * Do something...
     */  

ข้อมูลเพิ่มเติมที่นี่และที่นี่


36

ดำเนินการคำสั่ง

psql -V

ที่ไหน

Vต้องอยู่ในเมืองหลวง


8
นั่นคือpsql(ลูกค้า) รุ่นไม่รุ่นของ Postgres เซิร์ฟเวอร์
a_horse_with_no_name

หากต้องการคำวิจารณ์ : หากคำตอบนั้นผิด แต่เป็นคำตอบ (เช่นความคิดเห็นหมายถึง) ไม่แนะนำให้ลบ: downvote! ดูตัวอย่างเช่น " คุณกำลังทำมันผิด: ข้ออ้างสำหรับการมีสุขภาพจิตดีในระดับต่ำคุณภาพโพสต์คิว " และ " เมื่อคำตอบที่ตอบคำถามผิดก็ไม่ได้เป็นคำตอบ? " นี่คือคำตอบ คุณอาจไม่เห็นด้วยกับมัน แต่มันเป็นความพยายามที่จะตอบคำถาม
Wai Ha Lee

19

ในเชลล์ psql.exe ดำเนินการ

\! psql -V

13
นี่จะให้เวอร์ชันของไคลเอ็นต์ postgre แก่เขา ฉันผอมที่ OP ขอรุ่นเซิร์ฟเวอร์ sql
SpKel

12

วิธีง่ายๆคือการตรวจสอบเวอร์ชันโดยการพิมพ์psql --versionเทอร์มินัล


3
โปรดทราบว่านี่จะบอกให้คุณทราบถึงเวอร์ชันของไคลเอ็นต์เท่านั้นซึ่งอาจแตกต่างจากเซิร์ฟเวอร์ ดูคำตอบของ @ simhumileco สำหรับวิธีการบัญญัติ
jstr

12

การใช้งานpgadmin4สามารถมองเห็นได้โดยดับเบิลคลิกเซิร์ฟเวอร์> server_name_here> แท็บคุณสมบัติ> รุ่น:

เวอร์ชัน 3.5:

pgadmin4 แสดงรุ่น postgres  เซิร์ฟเวอร์> server_name> คุณสมบัติ> เวอร์ชัน

เวอร์ชั่น 4.1, 4.5:

ป้อนคำอธิบายรูปภาพที่นี่


ไม่เห็น ใช้ pgadmin 4 เวอร์ชัน 4.1
faintsignal

1
@faintsignal เพิ่มสกรีนช็อตสำหรับ pgadmin4 v4.1 การกระโดดเวอร์ชันนั้นเกิดขึ้นอย่างรวดเร็ว
jmunsch

1
โอ้ความผิดพลาดของฉัน ฉันคิดว่าคุณคลิกขวาที่เซิร์ฟเวอร์ซึ่งนำไปสู่กล่องโต้ตอบ "คุณสมบัติ" อื่น ขอบคุณ!
faintsignal

9

คำสั่ง pg_config จะรายงานไดเรกทอรีที่ติดตั้งโปรแกรม PostgreSQL (--bindir) ตำแหน่งของ C ประกอบด้วยไฟล์ (- รวมถึง) และไลบรารีโค้ดวัตถุ (--libdir) และเวอร์ชันของ PostgreSQL (- รุ่น) :

$ pg_config --version
PostgreSQL 9.3.6

8

ในกรณีของฉัน

$psql
postgres=# \g
postgres=# SELECT version();
                                                       version
---------------------------------------------------------------------------------------------------------------------
 PostgreSQL 8.4.21 on x86_64-pc-linux-gnu, compiled by GCC gcc-4.6.real (Ubuntu/Linaro 4.6.3-1ubuntu5) 4.6.3, 64-bit
(1 row)

หวังว่ามันจะช่วยใครซักคน


4

หากคุณมีการเข้าถึงเชลล์ไปยังเซิร์ฟเวอร์ (คำถามที่กล่าวถึง op ไม่ได้มี แต่ในกรณีที่คุณมี) ในระบบเดเบียน / อูบุนตู

sudo apt-cache policy postgresql

ซึ่งจะส่งออกรุ่นที่ติดตั้ง

postgresql:
  Installed: 9.6+184ubuntu1.1
  Candidate: 9.6+184ubuntu1.1
  Version table:
 *** 9.6+184ubuntu1.1 500
        500 http://in.archive.ubuntu.com/ubuntu artful-updates/main amd64 Packages
        500 http://in.archive.ubuntu.com/ubuntu artful-updates/main i386 Packages
        500 http://security.ubuntu.com/ubuntu artful-security/main amd64 Packages
        500 http://security.ubuntu.com/ubuntu artful-security/main i386 Packages
        100 /var/lib/dpkg/status
     9.6+184ubuntu1 500
        500 http://in.archive.ubuntu.com/ubuntu artful/main amd64 Packages
        500 http://in.archive.ubuntu.com/ubuntu artful/main i386 Packages

โดยที่Installed: <version>เป็นเวอร์ชันแพ็คเกจของ postgres ที่ติดตั้งไว้


1
ในความคิดที่คล้ายกันฉันวิ่ง$ yum listไปดูแพ็คเกจ Postgresql บางตัวที่ติดตั้ง
แพทริค

มันใช้งานได้ดี คุณช่วยกรุณาระบุวิธีการอัปเกรดจาก 9.6 เป็น 10 ใน Ubuntu 16.04
kRazzy R


2

ไม่ทราบว่าสิ่งนี้น่าเชื่อถือเพียงใด แต่คุณสามารถรับโทเค็นรุ่นสองอย่างอัตโนมัติ:

psql --version 2>&1 | tail -1 | awk '{print $3}' | sed 's/\./ /g' | awk '{print $1 "." $2}'

ดังนั้นคุณสามารถสร้างเส้นทางไปยังไบนารี:

/usr/lib/postgresql/9.2/bin/postgres

เพียงแทนที่ 9.2 ด้วยคำสั่งนี้


psql --versionส่งคืนเวอร์ชันของpsqlไคลเอ็นต์ไม่ใช่เวอร์ชันของเซิร์ฟเวอร์ Postgres
a_horse_with_no_name

1

สำหรับเวอร์ชั่นปัจจุบันของ PgAdmin: 4.16 ณ เวลาที่เขียน

  1. เลือกฐานข้อมูลที่คุณต้องการ
  2. คลิกที่แท็บคุณสมบัติในบานหน้าต่างด้านขวา

ดูภาพหน้าจอด้านล่าง: PGAdmin 4.16 แสดง DB เวอร์ชัน 10.10


0

หากSelect version()กลับมาพร้อมกับบันทึกลองใช้คำสั่งด้วยวิธีนี้:

Select version::char(100) 

หรือ

Select version::varchar(100)

2
select version()::varchar(100);ทำงานให้ฉัน แต่เหมือนกันกับversion()
isaaclw
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.