当前位置: 首页 > news >正文

如何在 Debian 8 上安装和使用 PostgreSQL 9.4

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。

简介

关系型数据库是满足多种需求的数据组织的基石。它们支持从在线购物到火箭发射等各种应用。PostgreSQL 是一种历史悠久但仍然活跃的数据库,它遵循大部分 SQL 标准,支持 ACID 事务,支持外键和视图,并且仍在积极开发中。

如果你运行的应用程序需要稳定性、软件包质量和简单的管理,Debian 8(代号“Jessie”)是 Linux 发行版中最佳的选择之一。它的更新速度比其他“发行版”慢一些,但其稳定性和质量得到了广泛认可。如果你的应用程序或服务需要数据库,Debian 8 和 PostgreSQL 的组合是最佳选择之一。

本文将向您展示如何在新的 Debian 8 Stable 实例上安装 PostgreSQL 并开始使用。

先决条件

首先要做的是启动 Debian 8 Stable 系统。你可以按照《使用 Debian 8 进行初始服务器设置》中的说明进行操作。本教程假设你已经准备好了一个 Debian 8 Stable Droplet。

除非另有说明,本教程中的所有命令都应该以具有 sudo 权限的非 root 用户身份运行。要了解如何创建用户并授予他们 sudo 权限,请查看《使用 Debian 8 进行初始服务器设置》。

安装 PostgreSQL

在安装 PostgreSQL 之前,请确保通过以下命令更新 apt 软件包列表,以获取来自 Debian 软件仓库的最新信息:

sudo apt-get update

你应该看到软件包列表正在更新,并出现以下消息:

Reading package lists... Done.

有几个以 postgresql 开头的软件包:

  • postgresql-9.4:PostgreSQL 服务器软件包
  • postgresql-client-9.4:PostgreSQL 客户端
  • postgresql:Debian 手册或 Debian 新维护者指南中更好解释的“元软件包”

要直接安装 postgresql-9.4 软件包:

sudo apt-get install postgresql-9.4 postgresql-client-9.4

在提示时,输入 Y 安装软件包。如果一切顺利,软件包现在已从软件仓库下载并安装。

检查安装

要检查 PostgreSQL 服务器是否正确安装并正在运行,可以使用 ps 命令:

ps -ef | grep postgre

你应该在终端上看到类似以下内容:

postgres 32164     1  0 21:58 ?        00:00:00 /usr/lib/postgresql/9.4/bin/postgres -D /var/lib/   postgresql/9.4/main -c config_file=/etc/postgresql/9.4/main/postgresql.conf
postgres 32166 32164  0 21:58 ?        00:00:00 postgres: checkpointer process
postgres 32167 32164  0 21:58 ?        00:00:00 postgres: writer process
postgres 32168 32164  0 21:58 ?        00:00:00 postgres: wal writer process
postgres 32169 32164  0 21:58 ?        00:00:00 postgres: autovacuum launcher process
postgres 32170 32164  0 21:58 ?        00:00:00 postgres: stats collector process 

成功!PostgreSQL 已成功安装并正在运行。

访问 PostgreSQL 数据库

在 Debian 上,PostgreSQL 安装了一个名为 postgres 的默认用户和默认数据库。要连接到数据库,首先需要切换到 postgres 用户,方法是在以 root 用户登录的情况下发出以下命令(使用 sudo 权限无法执行此操作):

su - postgres

现在你应该已经以 postgres 用户登录。要启动 PostgreSQL 控制台,输入 psql

psql

完成!你应该已经登录到 PostgreSQL 控制台。你应该看到以下提示:

psql (9.4.2)
Type "help" for help.postgres=# 

要退出 psql 控制台,只需使用命令 \q

创建新角色

默认情况下,Postgres 使用称为“角色”的概念来帮助进行身份验证和授权。在某些方面,这些与常规的 Unix 风格帐户类似,但 PostgreSQL 不区分用户和组,而是更倾向于更灵活的术语“角色”。

在安装时,PostgreSQL 被设置为使用“ident”身份验证,这意味着它将 PostgreSQL 角色与匹配的 Unix/Linux 系统帐户关联起来。如果存在 PostgreSQL 角色,可以通过登录到关联的 Linux 系统帐户来登录。

安装过程创建了一个名为 postgres 的用户帐户,该帐户与默认的 Postgres 角色关联。

要创建其他角色,我们可以使用 createuser 命令。请注意,此命令应该作为用户 postgres 发出,而不是在 PostgreSQL 控制台内部:

createuser --interactive

这基本上是一个交互式的 shell 脚本,调用正确的 PostgreSQL 命令来根据你的规格创建用户。它会询问你一些问题:角色的名称、是否应该是超级用户、角色是否应该能够创建新数据库,以及角色是否能够创建新角色。man 页面中有更多信息:

man createuser

创建新数据库

PostgreSQL 默认设置了通过匹配系统帐户请求的身份验证角色(您可以在 postgresql.org 上获取更多信息)。它还假定匹配的数据库将存在于角色连接的数据库中。因此,如果我有一个名为 test1 的用户,该角色将默认尝试连接到名为 test1 的数据库。

您可以通过简单地以 postgres 用户的身份调用以下命令来创建适当的数据库:

createdb test1

现在已创建了新数据库 test1

使用新用户连接到 PostgreSQL

假设您有一个名为 test1 的 Linux 帐户,创建了一个 PostgreSQL test1 角色与之匹配,并创建了数据库 test1。要在 Linux 中切换用户帐户为 test1

su - test1

然后,使用以下命令以 test1 PostgreSQL 角色连接到 test1 数据库:

psql

现在,您应该看到新创建的用户 test1 而不是 postgres 的 PostgreSQL 提示符。

创建和删除表

现在您知道如何连接到 PostgreSQL 数据库系统,我们将开始介绍如何完成一些基本任务。

首先,让我们创建一个表来存储一些数据。让我们创建一个描述游乐场设备的表。

此命令的基本语法如下:

CREATE TABLE table_name (column_name1 col_type (field_length) column_constraints,column_name2 col_type (field_length),column_name3 col_type (field_length)
);

如您所见,我们为表指定了一个名称,然后定义了我们想要的列,以及列类型和字段数据的最大长度。我们还可以为每个列可选地添加表约束。

您可以在《如何在云服务器上创建、删除和管理 PostgreSQL 表》文章中了解有关如何在 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,它是序列类型的。此数据类型是自增整数。我们已经给了这个列主键的约束,这意味着值必须是唯一的且不为空。

对于我们的两个列,我们没有给出字段长度。这是因为某些列类型不需要设置长度,因为长度由类型隐含确定。

然后,我们为设备类型和颜色创建列,每个列都不能为空。然后我们创建一个位置列,并创建一个要求值为八个可能值之一的约束。最后一列是一个记录我们安装设备日期的日期列。

要查看表,请在 psql 提示符上使用命令 \dt。结果类似于

             List of relationsSchema |    Name    | Type  |  Owner 
--------+------------+-------+----------public | playground | table | postgres

如您所见,我们有我们的游乐场表。

向表中添加、查询和删除数据

现在我们已经创建了一个表,我们可以向其中插入一些数据。

让我们添加一个滑梯和一个秋千。我们通过调用我们要添加到的表,命名列,然后为每个列提供数据来完成这个操作。我们的滑梯和秋千可以这样添加:

INSERT INTO playground (type, color, location, install_date) VALUES ('slide', 'blue', 'south', '2014-04-28');
INSERT INTO playground (type, color, location, install_date) VALUES ('swing', 'yellow', 'northwest', '2010-08-16');

您应该注意到几件事情。首先,请记住,列名不应该用引号括起来,但您输入的列值确实需要引号。

另一件需要注意的事情是,我们不为 equip_id 列输入值。这是因为每当在表中创建新行时,此列会自动生成。

然后,我们可以通过键入以下内容来获取我们添加的信息:

SELECT * FROM playground;

输出应该是

 equip_id | type  | color  | location  | install_date 
----------+-------+--------+-----------+--------------1 | slide | blue   | south     | 2014-04-282 | swing | yellow | northwest | 2010-08-16

在这里,您可以看到我们的 equip_id 已成功填充,并且我们的其他所有数据都已正确组织。如果我们的滑梯损坏,并且我们将其从游乐场移除,我们也可以通过键入以下内容从我们的表中删除该行:

DELETE FROM playground WHERE type = 'slide';

如果我们再次查询我们的表:

SELECT * FROM playground;

我们将看到我们的滑梯不再是表的一部分:

 equip_id | type  | color | location | install_date 
----------+-------+-------+----------+--------------1 | slide | blue  | south    | 2014-04-28

有用的命令

以下是一些可以帮助您了解当前环境的命令:

  • ?: 获取包括这里未列出的所有 psql 命令的完整列表。

  • \h: 获取有关 SQL 命令的帮助。您可以在其后跟上特定命令以获取语法帮助。

  • \q: 退出 psql 程序并返回到 Linux 提示符。

  • \d: 列出当前数据库中可用的表、视图和序列。

  • \du: 列出可用角色。

  • \dp: 列出访问权限。

  • \dt: 列出表格。

  • \l: 列出数据库。

  • \c: 连接到不同的数据库。在其后跟上数据库名称。

  • \password: 更改接下来的用户名的密码。

  • \conninfo: 获取有关当前数据库和连接的信息。

有了这些命令,您应该能够在短时间内浏览 PostgreSQL 数据库、表格和角色。

结论

您现在应该在 Debian 系统上拥有一个完全功能的 PostgreSQL 数据库。恭喜!这里有大量的文档可供参考:

  • PostgreSQL 手册

  • 安装包 postgresql-docsudo apt-get install postgresql-doc

  • 安装在 /usr/share/doc/postgresql-doc-9.4/tutorial/READMEREADME 文件

要获取 PostgreSQL 中支持的所有 SQL 命令的完整列表,请访问以下链接:

  • SQL 命令

要比较不同数据库的功能,请查看:

  • SQLite vs MySQL vs PostgreSQL

要更好地理解角色和权限,请参阅:

  • 如何在 VPS 上使用角色和管理授予权限的 PostgreSQL

相关文章:

如何在 Debian 8 上安装和使用 PostgreSQL 9.4

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 简介 关系型数据库是满足多种需求的数据组织的基石。它们支持从在线购物到火箭发射等各种应用。PostgreSQL 是一种历史悠久但仍然活跃的…...

【微信小程序】微信小程序设置本地背景图片在真机无法显示的解决方案

微信小程序设置本地背景图片在真机无法显示的解决方案 在开发微信小程序时,很多开发者会遇到一个常见的问题:在调试环境中设置本地背景图片可以正常显示,但在真机上却无法显示。本文将详细探讨这一问题的原因,并提供三种解决方案…...

Arthas在线诊断案例实战整理

Arthas - Java 应用诊断利器 Arthas 是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息,并能在不修改应用代码的情况下,对业务问题进行诊断,包括查看方法调用的出入参、异常,监测方法…...

使用 XRDP 远程linux主机

一、简介 XRDP是一个开源的远程桌面协议(Remote Desktop Protocol,RDP)服务器,采用的是标准的RDP。 官网地址:https://www.xrdp.org/ github地址: https://github.com/neutrinolabs/xrdp/releases XRDP也是C/S架构&…...

学习小型gpt源码(自用)

数据集构建_哔哩哔哩_bilibili (b站上有一系列课,从数据处理到模型构建和训练使用) 什么是batch? 为什么一个batch内的句子要一样长? 不同batch的长度可以不一样,但是同一个batch内长度一样!…...

@Transactional使用的注意事项

在项目中涉及到CRUD操作时,一般都会在方法上添加该注解,以为加上Transactional,Spring就可以自动帮我们进行事务的开启、提交 有一个很多人都会犯的误区: 将Spring事务与Transactional划上了等号,只要有数据库相关操作…...

快手可灵视频生成大模型全方位测评

快手视频生成大模型“可灵”(Kling),是全球首个真正用户可用的视频生成大模型,自面世以来,凭借其无与伦比的视频生成效果,在全球范围内赢得了用户的热烈追捧与高度评价。截至目前,申请体验其内测…...

【JavaScript】`Map` 数据结构

文章目录 一、Map 的基本概念二、常见操作三、与对象的对比四、实际应用场景 在现代 JavaScript 中,Map 是一种非常重要且强大的数据结构。与传统的对象(Object)不同,Map 允许您使用各种类型的值作为键,不限于字符串或…...

Ubuntu22.04使用NVM安装多版本Node.js和版本切换

Fabric官方目前支持Node.js开发区块链应用,建议使用Node长期支持版本(LTS)。 建议使用NVM安装Node.js,NVM可以帮助我们方便的在Node的不同版本之间进行切换,这样我们就可以同时工作在不同的项目上。 下面是安装的脚本…...

基于C51和OLED12864实现Goole小恐龙

在数字娱乐领域,Google小恐龙(T-Rex Runner)以其简单而上瘾的游戏机制赢得了广泛的关注和喜爱。这款内置于Chrome浏览器的离线小游戏,不仅为用户带来了乐趣,也激发了开发者们对其进行各种创新和扩展的灵感。本文将介绍…...

【Docker】CentOS7环境下的安装

环境展示 安装 配置仓库 sudo yum install -y yum-utils # docker官方key文件下载 sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo # 建议使用阿里云key文件下载 sudo yum-config-manager --add-repo https://mirrors.aliyun.…...

浏览器的最大并发数(http1.1)

HTTP/1.1:每个资源请求通常需要单独的TCP连接,尽管支持Keep-Alive机制,允许在同一个TCP连接上连续发送多个请求。但通常浏览器限制并发TCP连接数(例如,每个域名最多6个并发连接)。 HTTP/2:引入…...

Android 开发中px、dpi 和 dp三个单位的介绍

Android 开发中px、dpi 和 dp三个单位的介绍 在 Android 开发中,px、dpi 和 dp 是用来描述屏幕尺寸和密度的单位,它们在设计和开发中有着不同的作用和用途。 1. px(像素) 定义: px 表示屏幕上的一个像素点&#xff0c…...

zookeeper开启SASL权限认证

目录 一、SASL介绍 二、使用 SASL 进行身份验证 2.1 服务器到服务器的身份验证 2.2 客户端到服务器身份验证 三、验证功能 一、SASL介绍 默认情况下,ZooKeeper 不使用任何形式的身份验证并允许匿名连接。但是,它支持 Java 身份验证与授权服务(JAAS)…...

mysql一个小问题引发的思考-mysql类型转换-查询缓存 及 MYSQL查询缓存以及自动选择不使用查询缓存的情况

一、mysql一个小问题引发的思考-mysql类型转换-查询缓存 最近在做的一个项目中有一个SQL语句发现点问题,大概如下: select * from table where cid0 or find_in_set(1, cid); 数据表中的字段cid是字符串类型,原来的后端同学未提过此字段还能是…...

css更改图片颜色

css更改图片颜色&#xff0c;比较时候颜色单一的图片&#xff0c;比如logo之类的 css中的 filter 属性定义元素&#xff08;通常是 <img>&#xff09;的视觉效果&#xff08;如模糊和饱和度&#xff09; img{ -webkit-filter: invert(51%) sepia(94%) saturate(6433%) h…...

通过POST请求往Elastic批量插入数据

文章目录 引言I 请求文档请求参数请求例子引言 调试工具:Apifox 需求: 向Elasticsearch中的’test_index’索引批量插入文档 情况认证: Basic Auth 在 Header 添加参数 Authorization,其值为在 Basic 之后拼接空格,以及经过 Base64 编码的 {{Username}}:{{Password}} 示…...

JAW:一款针对客户端JavaScript的图形化安全分析框架

关于JAW JAW是一款针对客户端JavaScript的图形化安全分析框架&#xff0c;该工具基于esprima解析器和EsTree SpiderMonkey Spec实现其功能&#xff0c;广大研究人员可以使用该工具分析Web应用程序和基于JavaScript的客户端程序的安全性。 工具特性 1、动态可扩展的框架&#x…...

错误解决 error CS0117: ‘Buffer‘ does not contain a definition for ‘BlockCopy‘

Unity 2022.3.9f1 导入 Runtime OBJ Importer 后出现&#xff1a; error CS0117: ‘Buffer’ does not contain a definition for ‘BlockCopy’ 解决办法&#xff1a; 源代码&#xff1a; int DDS_HEADER_SIZE 128; byte[] dxtBytes new byte[ddsBytes.Length - DDS_HEAD…...

ICMPv6与DHCPv6之网络工程师软考中级

ICMPv6概述 ICMPv6是IPv6的基础协议之一。 在IPv6报文头部中&#xff0c;Next Header字段值为58则对应为ICMPv6报文。 ICMPv6报文用于通告相关信息或错误。 ICMPv6报文被广泛应用于其它协议中&#xff0c;包括NDP、Path MTU发现机制等 ICMPv6控制着IPv6中的地址自动配置、地址…...

第一篇:Agent2Agent (A2A) 协议——协作式人工智能的黎明

AI 领域的快速发展正在催生一个新时代&#xff0c;智能代理&#xff08;agents&#xff09;不再是孤立的个体&#xff0c;而是能够像一个数字团队一样协作。然而&#xff0c;当前 AI 生态系统的碎片化阻碍了这一愿景的实现&#xff0c;导致了“AI 巴别塔问题”——不同代理之间…...

【OSG学习笔记】Day 16: 骨骼动画与蒙皮(osgAnimation)

骨骼动画基础 骨骼动画是 3D 计算机图形中常用的技术&#xff0c;它通过以下两个主要组件实现角色动画。 骨骼系统 (Skeleton)&#xff1a;由层级结构的骨头组成&#xff0c;类似于人体骨骼蒙皮 (Mesh Skinning)&#xff1a;将模型网格顶点绑定到骨骼上&#xff0c;使骨骼移动…...

【开发技术】.Net使用FFmpeg视频特定帧上绘制内容

目录 一、目的 二、解决方案 2.1 什么是FFmpeg 2.2 FFmpeg主要功能 2.3 使用Xabe.FFmpeg调用FFmpeg功能 2.4 使用 FFmpeg 的 drawbox 滤镜来绘制 ROI 三、总结 一、目的 当前市场上有很多目标检测智能识别的相关算法&#xff0c;当前调用一个医疗行业的AI识别算法后返回…...

快刀集(1): 一刀斩断视频片头广告

一刀流&#xff1a;用一个简单脚本&#xff0c;秒杀视频片头广告&#xff0c;还你清爽观影体验。 1. 引子 作为一个爱生活、爱学习、爱收藏高清资源的老码农&#xff0c;平时写代码之余看看电影、补补片&#xff0c;是再正常不过的事。 电影嘛&#xff0c;要沉浸&#xff0c;…...

GO协程(Goroutine)问题总结

在使用Go语言来编写代码时&#xff0c;遇到的一些问题总结一下 [参考文档]&#xff1a;https://www.topgoer.com/%E5%B9%B6%E5%8F%91%E7%BC%96%E7%A8%8B/goroutine.html 1. main()函数默认的Goroutine 场景再现&#xff1a; 今天在看到这个教程的时候&#xff0c;在自己的电…...

HubSpot推出与ChatGPT的深度集成引发兴奋与担忧

上周三&#xff0c;HubSpot宣布已构建与ChatGPT的深度集成&#xff0c;这一消息在HubSpot用户和营销技术观察者中引发了极大的兴奋&#xff0c;但同时也存在一些关于数据安全的担忧。 许多网络声音声称&#xff0c;这对SaaS应用程序和人工智能而言是一场范式转变。 但向任何技…...

git: early EOF

macOS报错&#xff1a; Initialized empty Git repository in /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core/.git/ remote: Enumerating objects: 2691797, done. remote: Counting objects: 100% (1760/1760), done. remote: Compressing objects: 100% (636/636…...

Sklearn 机器学习 缺失值处理 获取填充失值的统计值

💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 使用 Scikit-learn 处理缺失值并提取填充统计信息的完整指南 在机器学习项目中,数据清…...

Python 高级应用10:在python 大型项目中 FastAPI 和 Django 的相互配合

无论是python&#xff0c;或者java 的大型项目中&#xff0c;都会涉及到 自身平台微服务之间的相互调用&#xff0c;以及和第三发平台的 接口对接&#xff0c;那在python 中是怎么实现的呢&#xff1f; 在 Python Web 开发中&#xff0c;FastAPI 和 Django 是两个重要但定位不…...

【系统架构设计师-2025上半年真题】综合知识-参考答案及部分详解(回忆版)

更多内容请见: 备考系统架构设计师-专栏介绍和目录 文章目录 【第1题】【第2题】【第3题】【第4题】【第5题】【第6题】【第7题】【第8题】【第9题】【第10题】【第11题】【第12题】【第13题】【第14题】【第15题】【第16题】【第17题】【第18题】【第19题】【第20~21题】【第…...