如何在Ubuntu 18.04上安装和使用PostgreSQL

摘要:
如何在Ubuntu 18.04上安装和使用PostgreSQL关系数据库管理系统是许多网站和应用程序的关键组件。本指南演示如何在Ubuntu 18.04 VPS实例上安装Postgres,并提供有关基本数据库管理的说明。使用PostgreSQL角色和数据库默认情况下,Postgre使用名为“角色”的概念来处理身份验证和授权。安装后,Postgres设置为使用身份验证,这意味着它将Postgres角色与匹配的Unix/Linux系统帐户相关联。如果Postgres中存在角色,则具有相同名称的Unix/Linux用户名可以作为角色登录。
 
如何在Ubuntu 18.04上安装和使用PostgreSQL
关系数据库管理系统是许多网站和应用程序的关键组成部分。它们提供了一种结构化的方式来存储,组织和访问信息。

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命令以根据您的规范创建用户。

Output

Enter name of role to add: sammyShall 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

Output

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_idinstall_date),这些命令不指定字段长度。这是因为某些列类型不需要设置长度,因为该类型隐含了长度。

接下来的两个命令的设备创建列typecolor分别,其中每一个可以不为空。这些命令之后创建一个location列并创建一个约束条件,要求该值为八个可能的值之一。最后一个命令创建一个日期列,记录您安装设备的日期。

您可以输入以下内容来查看新表:

d

Output

                  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

Output

          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;

Output

 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;

Output

 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;

Output

 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;

Output

 equip_id | type  | color | location  | install_date ----------+-------+-------+-----------+--------------        2 | swing | red   | northwest | 2010-08-16(1 row)

正如你所看到的,你的幻灯片现在被注册为红色。

免责声明:文章转载自《如何在Ubuntu 18.04上安装和使用PostgreSQL》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇CVEcentos 6.5环境利用iscsi搭建SAN网络存储服务及服务端target和客户端initiator配置详解下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

三大数据库中的主键自增对比

首先是最简单的sql server数据库 创建个表吧 create table aa (   id int primary key identity(1,1)     //这个就代表id自增了  id是从1开始每次自增1  非常简单  不用学就会 ) 然后是mysql  也是so easy create table bb ( chatId int NOT...

SQL Server 本地数据库登录不上 解决方法

sql本地数据库登录不了的话。先看看自己计算机 服务 SQL server  (MSSQLSERVER)  没有打开的话,请打开。 今天说的情景模式是  你误删了windows登录;禁用了sa登录;sa密码忘记了;或是你计算机名字被公司修改了,老的名字忘记了;又或是你用的别人的之前安装好的SQL数据库,终归,你本地数据库登录不了,用不了,拉了胯。   1...

【SQL Server学习笔记】通过加密来保护数据库中的数据

在SQL Server 2005引入了内建数据加密,通过系统函数、证书、密钥完成加密。 一、通过函数加密。 二、与通过证书授权实现的数字证书相似,SQL Server证书包括了公钥和私钥这一对密钥,是数据库级的安全对象,他们用来加密和解密数据。 三、SQL Server还拥有创建非对称密钥和对称密钥的能力。非对称密钥与证书相似,公钥用来加密数据库,私钥用来...

数据库连接,事务以及Java线程的关系

0. 前言 Spring作为Java框架王者,当前已经是基础容器框架的实际标准。Spring 除了提供了IoC、AOP特性外,还有一个极其核心和重要的特性:数据库事务。事务管理涉及到的技术点比较多,想完全理解需要花费一定的时间,本系列《Spring设计思想-事务篇》将通过如下几个方面来阐述Spring的数据库事务: 数据库连接java.sql.Conne...

SpringBoot简单连接数据库以及查询数据

实现大概思路:配置数据库环境——>实体类——>新建**Repostory接口并且继承JpaRepository——>配置URL映射以及请求方式— 首先,在数据库中新建名称为dbgirl数据库,在application.yml文件中进行对数据库以及JPA的配置,代码如下。 spring: profiles: active: de...

数据库启动的三个台阶nomount,mount,open(转载)

目的是明白细化启动数据库的三个步骤启动数据库到nomount状态的条件如下。如果你是非windows OS 就没有注册表,而有环境变量服务中的OracleService必须启动服务的名称和注册表中的oracle_sid相匹配存在正确的密码文件和参数文件有足够的内存参数文件中描述的路径必须存在数据库产品安装正确 conn sys/oracle as sysd...