Ubuntu1804安装Postgresql【转】
转载自:https://huur.cn/course/yw/1591.html

关系数据库管理系统是许多网站和应用程序的关键组成部分。它们提供了一种结构化的方式来存储,组织和访问信息。
PostgreSQL或Postgres是一个关系数据库管理系统,提供SQL查询语言的实现。它是许多小型和大型项目的流行选择,并且具有符合标准并具有许多高级功能(如可靠事务和并发读取锁)的优点。
本指南演示了如何在Ubuntu 18.04 VPS实例上安装Postgres,并提供了有关基本数据库管理的说明。
先决条件
为了跟随本教程,您将需要一个Ubuntu 18.04服务器,该服务器已通过遵循我们的初始服务器设置Ubuntu 18.04指南进行配置。完成此先决条件教程后,您的服务器应该有一个非root用户,具有sudo权限和基本防火墙。
安装PostgreSQL
Ubuntu的默认存储库包含Postgres软件包,因此您可以使用apt打包系统安装这些软件包。
由于这是您第一次apt在此会话中使用,请刷新本地包裹索引。然后,安装Postgres软件包以及-contrib增加一些附加实用程序和功能的软件包:
sudo apt update
sudo apt install postgresql postgresql-contrib
现在安装了该软件,我们可以了解它的工作原理以及它可能与您可能使用的类似数据库管理系统的不同之处。
使用PostgreSQL角色和数据库
默认情况下,Postgres使用称为“角色”的概念来处理身份验证和授权。这些在某些方面类似于普通的Unix风格的账户,但是Postgres并没有区分用户和组,而是倾向于更灵活的术语“角色”。
安装后,Postgres被设置为使用ident身份验证,这意味着它将Postgres角色与匹配的Unix / Linux系统帐户相关联。如果Postgres中存在一个角色,则具有相同名称的Unix / Linux用户名可以作为该角色登录。
安装过程创建了一个名为postgres的用户帐户,它与默认的Postgres角色相关联。为了使用Postgres,您可以登录到该帐户。
有几种方式可以使用此帐户访问Postgres。
切换到postgres帐户
输入以下内容切换到服务器上的postgres帐户:
sudo -i -u postgres
您现在可以通过键入以下命令立即访问Postgres提示符:
psql
这会将您登录到PostgreSQL提示符中,从这里您可以立即与数据库管理系统进行交互。
输入以下命令退出PostgreSQL提示符:
\q
这会将您带回到postgresLinux命令提示符。
在不切换帐户的情况下访问Postgres提示
你也可以直接用postgres账户运行你想要的命令sudo。
例如,在最后一个例子中,您被指示通过首先切换到postgres用户然后运行psql以打开Postgres提示符来访问Postgres提示符。您可以通过psql像postgres用户sudo一样运行单个命令来完成此操作,如下所示:
sudo -u postgres psql
这会将你直接登录到Postgres中,而不需要中间的bashshell。
同样,您可以键入以下命令退出交互式Postgres会话:
\q
许多用例需要多个Postgres角色。继续阅读以了解如何配置这些。
创建一个新的角色
目前,您只需在数据库中配置postgres角色。您可以使用命令从命令行创建新角色createrole。该--interactive标志会提示您输入新角色的名称,并询问它是否应具有超级用户权限。
如果您以postgres帐户登录,则可以通过键入以下内容创建新用户:
createuser --interactive
相反,如果您宁愿使用sudo每个命令而不从普通帐户切换,请键入:
sudo -u postgres createuser --interactive
该脚本会提示您一些选择,并根据您的响应执行正确的Postgres命令以根据您的规范创建用户。
Enter name of role to add: sammy
Shall the new role be a superuser? (y/n) y
通过传递一些额外的标志可以获得更多控制权。通过查看man页面查看选项:
man createuser
你现在安装的Postgres有一个新用户,但你还没有添加任何数据库。下一节将介绍这一过程。
创建一个新的数据库
Postgres身份验证系统默认情况下的另一个假设是,对于用于登录的任何角色,该角色将具有可访问的同名数据库。
这意味着,如果您在上一节中创建的用户名为sammy,则该角色将尝试连接到默认情况下也称为“sammy”的数据库。您可以使用该createdb命令创建适当的数据库。
如果您以postgres帐户登录,则可以键入如下所示的内容:
createdb sammy
相反,如果您宁愿使用sudo每个命令而无需从普通帐户中切换,则可以键入:
sudo -u postgres createdb sammy
这种灵活性可根据需要为创建数据库提供多种路径
以新的角色打开Postgres提示
要使用ident基于身份验证的身份登录,您需要一名与Postgres角色和数据库名称相同的Linux用户。
如果您没有可用的匹配Linux用户,则可以使用该adduser命令创建一个。您必须从您的非root用户帐户拥有sudo权限(意思是,未以postgres用户身份登录)执行此操作:
sudo adduser sammy
一旦这个新帐户可用,您可以通过键入以下命令切换并连接到数据库:
sudo -i -u sammy
psql
或者,你可以这样做内联:
sudo -u sammy psql
假设所有组件都已正确配置,此命令将自动登录。
如果你想让你的用户连接到不同的数据库,你可以通过像这样指定数据库来实现:
psql -d postgres</span
登录后,您可以输入以下内容来检查当前的连接信息:
\conninfo
You are connected to database "sammy" as user "sammy" via socket in "/var/run/postgresql" at port "5432".
如果您连接到非默认数据库或非默认用户,这很有用。
创建和删除表格
现在您已经知道如何连接到PostgreSQL数据库系统,您可以学习一些基本的Postgres管理任务。
首先,创建一个表来存储一些数据。作为一个例子,描述一些游乐场设备的表格。
该命令的基本语法如下所示:
CREATE TABLE table_name (
column_name1 col_type (field_length) column_constraints,
column_name2 col_type (field_length),
column_name3 col_type (field_length)
);
正如你所看到的,这些命令为表提供了一个名称,然后定义列以及列类型和字段数据的最大长度。您也可以选择为每列添加表约束。
您可以在这里了解更多关于如何在Postgres中创建和管理表格的信息。
为了演示目的,请创建一个如下所示的简单表格:
CREATE TABLE playground (
equip_id serial PRIMARY KEY,
type varchar (50) NOT NULL,
color varchar (25) NOT NULL,
location varchar(25) check (location in ('north', 'south', 'west', 'east', 'northeast', 'southeast', 'southwest', 'northwest')),
install_date date
);
这些命令将创建一个库存游乐场设备的表格。这从一个设备ID开始serial。此数据类型是一个自动递增整数。你也给了这个列的约束,primary key这意味着这些值必须是唯一的而不是空的。
对于两列(equip_id和install_date),这些命令不指定字段长度。这是因为某些列类型不需要设置长度,因为该类型隐含了长度。
接下来的两个命令的设备创建列type和color分别,其中每一个可以不为空。这些命令之后创建一个location列并创建一个约束条件,要求该值为八个可能的值之一。最后一个命令创建一个日期列,记录您安装设备的日期。
您可以输入以下内容来查看新表:
\d
List of relations
Schema | Name | Type | Owner
--------+-------------------------+----------+-------
public | playground | table | sammy
public | playground_equip_id_seq | sequence | sammy
(2 rows)
你的游乐场桌子在这里,但也有一些叫做playground_equip_id_seq这种类型的东西sequence。这是serial您为equip_id专栏提供的类型的表示形式。这会跟踪序列中的下一个数字,并为此类型的列自动创建。
如果你想只看到没有序列的表格,你可以输入:
\dt
List of relations
Schema | Name | Type | Owner
--------+------------+-------+-------
public | playground | table | sammy
(1 row)
在表中添加,查询和删除数据
现在您已经有了一个表格,您可以在其中插入一些数据。
例如,通过调用要添加的表来添加幻灯片和摆动,命名列,然后为每列提供数据,如下所示:
INSERT INTO playground (type, color, location, install_date) VALUES ('slide', 'blue', 'south', '2017-04-28');
INSERT INTO playground (type, color, location, install_date) VALUES ('swing', 'yellow', 'northwest', '2018-08-16');
输入数据时应小心,以避免几次常见的挂断。例如,不要将列名换成引号,但输入的列值需要引号。
另外要记住的是,您不输入equip_id列的值。这是因为无论何时创建表中的新行时都会自动生成这些数据。
通过输入以下内容检索您添加的信息:
SELECT * FROM playground;
equip_id | type | color | location | install_date
----------+-------+--------+-----------+--------------
1 | slide | blue | south | 2017-04-28
2 | swing | yellow | northwest | 2018-08-16
(2 rows)
在这里,你可以看到你的equip_id成功填写以及你所有其他数据的组织都是正确的。
如果操场上的幻灯片发生断裂并且您必须将其删除,则还可以键入以下内容以从表格中删除该行:
DELETE FROM playground WHERE type = 'slide';
再次查询表格:
SELECT * FROM playground;
equip_id | type | color | location | install_date
----------+-------+--------+-----------+--------------
2 | swing | yellow | northwest | 2018-08-16
(1 row)
您注意到您的幻灯片不再是表格的一部分。
从表中添加和删除列
创建表格后,可以对其进行修改以相对简单地添加或删除列。通过输入以下内容添加一列以显示每件设备的上次维护访问:
ALTER TABLE playground ADD last_maint date;
如果再次查看表格信息,则会看到已添加新列(但未输入任何数据):
SELECT * FROM playground;
equip_id | type | color | location | install_date | last_maint
----------+-------+--------+-----------+--------------+------------
2 | swing | yellow | northwest | 2018-08-16 |
(1 row)
删除列同样简单。如果您发现工作人员使用单独的工具来跟踪维护历史记录,则可以通过键入以下内容来删除该列:
ALTER TABLE playground DROP last_maint;
这将删除该last_maint列及其中找到的任何值,但保留所有其他数据不变。
更新表中的数据
到目前为止,您已经学会了如何向表中添加记录以及如何删除它们,但本教程尚未介绍如何修改现有条目。
您可以通过查询您想要的记录并将列设置为您希望使用的值来更新现有条目的值。您可以查询“摆动”记录(这将匹配表格中的每个摆动)并将其颜色更改为“红色”。如果你给挥杆设置一个油漆工作,这可能是有用的:
UPDATE playground SET color = 'red' WHERE type = 'swing';
您可以通过再次查询数据来验证操作是否成功:
SELECT * FROM playground;
equip_id | type | color | location | install_date
----------+-------+-------+-----------+--------------
2 | swing | red | northwest | 2010-08-16
(1 row)
正如你所看到的,你的幻灯片现在被注册为红色。
Ubuntu1804安装Postgresql【转】的更多相关文章
- [PostgreSQL] 图解安装 PostgreSQL
图解安装 PostgreSQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5894462.html 序 园友的一篇<Asp.Net Cor ...
- centos6.4下面安装postgresql以及客户端远程连接
一.安装 centos6.4服务器IP:192.168.220.131 window7客户端IP:192.168.199.218 在centos官网http://www.postgresql.org/ ...
- Linux CentOS安装postgresql 9.4
一.前言 PostgreSQL通常也简称Postgres,是一个关系型数据库管理系统,适用于各种Linux操作系统.Windows.Solaris.BSD和Mac OS X.PostgreSQL遵循P ...
- CentOS6.5下安装PostgreSQL
一.配置 YUM 仓库 修改原始的 yum 仓库配置: vim /etc/yum.repos.d/CentOS-Base.repo 在[base]和[updates] 节(section)部分的尾部插 ...
- 1.Windows安装PostgreSQL
按照下面的步骤,Windows机器上安装PostgreSQL.请确保已开启第三方防病毒,同时安装. 挑选你想要的PostgreSQL的版本号,可以点击以下链接下载 EnterpriseDB Windo ...
- centos 6.4下安装postgresql 9.2
我的linux版本是centos 6.4 ,准备安装postgresql 9.2 根据官方说明: http://www.postgresql.org/download/linux/redhat/ 缺省 ...
- 安装postgreSQL出现configure:error:readline library not found解决方法
要安装 readline , readline-dev 开发包,要么使用 --without-readline 选项关闭 readline 功能. #yum install readline; #yu ...
- ubuntu安装postgresql与postgis
版本信息 ubuntu 14.04.1LTS postgresql 9.3.5 postgis 2.1.2 今天尝试着安装了postgis 2.1.2,(较简便的包安装,不是源码 ...
- [zz]安装PostgreSQL数据库(Linux篇)
0.编译环境 Linux: CentOS 5.5 gcc: 4.1.2 1. 安装PostgreSQL 1) 解压postgresql-9.1.7.tar.bz2 #tar jxvf postgres ...
随机推荐
- cshtml中字符串中表示特殊字符@
用“@@”表示字符串中的特殊字符@
- / Vijos / 题库 /1250 / 最勇敢的机器人
/ Vijos / 题库 /1250 / 最勇敢的机器人 借鉴博客:http://www.cnblogs.com/chty/p/5830516.html 背景 Wind设计了很多机器人.但是它们都认为 ...
- MongoDB主库和从库的数据大小不一致原因判断
1. 环境(MongoDB的版本是3.2.16) [root@xxx-mongodb-primary ~]# cat /etc/redhat-release CentOS Linux release ...
- python爬虫13 | 秒爬,这多线程爬取速度也太猛了,这次就是要让你的爬虫效率杠杠的
快 快了 啊 嘿 小老弟 想啥呢 今天这篇爬虫教程的主题就是一个字 快 想要做到秒爬 就需要知道 什么是多进程 什么是多线程 什么是协程(微线程) 你先去沏杯茶 坐下来 小帅b这就好好给你说道说道 关 ...
- 第十节:numpy之数组文件操作
1.安装ipython 2.创建txt文件 3.直接上代码:
- router-link/ router-view 的使用
遇到的问题如下: 在菜单栏使用router-link配置菜单连接地址,使用router-view 显示连接地址的详细内容 首次配置的时候,使用router-link 配置好菜单之后,不知道如何使用ro ...
- 计算两个日期之间相差的年数月数天数(JS实现)
前言 如何计算年龄?我的第一直觉做法:(当前时间戳 - 出生时的时间戳)/ (365*86400) 所得结果向下取整.后来发现这种做法获得的结果不准确,不是多了一岁就是少了一岁,不能简单粗暴的这么处 ...
- PHP array_diff_uassoc()
定义和用法 array_diff_uassoc() 函数使用用户自定义的回调函数 (callback) 做索引检查来计算两个或多个数组的差集.返回一个数组,该数组包括了在 array1 中但是不在任何 ...
- Codeforces Round #305 (Div. 2) E题(数论+容斥原理)
E. Mike and Foam time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...
- 基数排序之多keyword排序运用队列
源码例如以下: #include <stdlib.h> #include <stdio.h> typedef struct QUEUEnode* link; struct QU ...