PostgreSQL基本用法
时间:2019-02-18 11:35 来源:未知 作者:IT
前言
PostgreSQL是一个开源的、对象关系型数据库管理系统(ORDBMS)。本文旨在介绍PostgreSQL(下文简称pg)的一些基本操作,供初学者参考和查阅。需要注意的是,以下所有操作是在Ubuntu 16.04中进行的,使用的pg版本是9.6。对于不同的操作系统和版本,操作流程可能有些许的差别,具体可以参看后面给出的参考文档中的内容。
安装
Ubuntu默认集成了pg,可以通过命令行直接安装
以下命令分别安装pg的客户端和服务端
$ sudo apt-get install postgresql-client
$ sudo apt-get install postgresql
安装完成后,通过以下命令即可启动pg
$ sudo service postgresql start
相应的,只要将这里的start改为stop和restart,就可以实现服务的停止和重启
创建一个数据库
在初次安装完成后,pg默认已经进行了如下的操作:创建了一个名为postgres的数据库用户和一个名为postgres的数据库,同时还创建了一个名为postgres的Linux系统用户。实际上,这里创建的postgres数据库用户拥有超级管理员身份,可以访问我们后面所创建的所有数据库,同时可以进行创建新数据库用户和修改用户密码等操作。
为了操作数据库,我们通常需要先登录控制台
$ sudo -u postgres psql
这条命令表示Linux用户postgres以超级用户postgres的身份登录了名为postgres的数据库,因为是Ubuntu系统,所以默认这个时候是不需要输入密码的,直接进入了pg的控制台
postgres=#
通常我们会在登录后先给postgres用户设置一下密码
postgres=# \password postgres
两次输入相同的密码后即可修改成功
因为postgers用户具有很高的权限,通常我们不会直接以这个身份登录,而是会另外创建一个新用户,比如创建一个和当前系统用户同名的数据库用户
postgres=# CREATE USER dbuser WITH PASSWORD 'password';
然后我们可以为这个新用户创建一个数据库
postgres=# CREATE DATABASE exampledb OWNER dbuser;
接下来我们就可以使用刚才创建的用户登录控制台并连接到创建的数据库中来进行一系列的操作了
$ psql -U dbuser -d exampledb
常用的控制台命令
\password 设置密码
\q 退出
\h 查看SQL命令的解释,比如\h select
\? 查看psql命令列表
\l 列出所有数据库
\c [database_name] 连接其他数据库
\d 列出当前数据库的所有表格
\d [table_name] 列出某一张表格的结构
\x 对数据做展开操作
\du 列出所有用户
备份和恢复
$ pg_dump --format=t -d db_name -U user_name -h 127.0.0.1 -O -W > dump.sql
$ psql -h 127.0.0.1 -U user_name db_name < dump.sql
(责任编辑:IT)
前言 PostgreSQL是一个开源的、对象关系型数据库管理系统(ORDBMS)。本文旨在介绍PostgreSQL(下文简称pg)的一些基本操作,供初学者参考和查阅。需要注意的是,以下所有操作是在Ubuntu 16.04中进行的,使用的pg版本是9.6。对于不同的操作系统和版本,操作流程可能有些许的差别,具体可以参看后面给出的参考文档中的内容。 安装 Ubuntu默认集成了pg,可以通过命令行直接安装 以下命令分别安装pg的客户端和服务端 $ sudo apt-get install postgresql-client $ sudo apt-get install postgresql 安装完成后,通过以下命令即可启动pg $ sudo service postgresql start 相应的,只要将这里的start改为stop和restart,就可以实现服务的停止和重启 创建一个数据库 在初次安装完成后,pg默认已经进行了如下的操作:创建了一个名为postgres的数据库用户和一个名为postgres的数据库,同时还创建了一个名为postgres的Linux系统用户。实际上,这里创建的postgres数据库用户拥有超级管理员身份,可以访问我们后面所创建的所有数据库,同时可以进行创建新数据库用户和修改用户密码等操作。 为了操作数据库,我们通常需要先登录控制台 $ sudo -u postgres psql 这条命令表示Linux用户postgres以超级用户postgres的身份登录了名为postgres的数据库,因为是Ubuntu系统,所以默认这个时候是不需要输入密码的,直接进入了pg的控制台 postgres=# 通常我们会在登录后先给postgres用户设置一下密码 postgres=# \password postgres 两次输入相同的密码后即可修改成功 因为postgers用户具有很高的权限,通常我们不会直接以这个身份登录,而是会另外创建一个新用户,比如创建一个和当前系统用户同名的数据库用户 postgres=# CREATE USER dbuser WITH PASSWORD 'password'; 然后我们可以为这个新用户创建一个数据库 postgres=# CREATE DATABASE exampledb OWNER dbuser; 接下来我们就可以使用刚才创建的用户登录控制台并连接到创建的数据库中来进行一系列的操作了 $ psql -U dbuser -d exampledb 常用的控制台命令 \password 设置密码 \q 退出 \h 查看SQL命令的解释,比如\h select \? 查看psql命令列表 \l 列出所有数据库 \c [database_name] 连接其他数据库 \d 列出当前数据库的所有表格 \d [table_name] 列出某一张表格的结构 \x 对数据做展开操作 \du 列出所有用户 备份和恢复 $ pg_dump --format=t -d db_name -U user_name -h 127.0.0.1 -O -W > dump.sql $ psql -h 127.0.0.1 -U user_name db_name < dump.sql (责任编辑:IT) |