Windows环境下安装PostgreSQL数据库指导

一、基本概念和特性

PostgreSQL是一个高度可扩展的开源对象关系数据库管理系统(ORDBMS),以其稳定性、强大的功能和对SQL标准的严格遵守而闻名。它支持丰富的数据类型和并发控制机制,并提供了活跃的社区支持。PostgreSQL的主要特性包括:

  • 开源性‌:完全免费,源代码开放,允许用户根据需要进行修改和扩展。
  • 跨平台性‌:支持多种操作系统,包括Linux、Windows、macOS等。
  • 标准兼容性‌:高度兼容SQL标准,支持复杂查询、事务、外键、视图、触发器和存储过程等。
  • 扩展性强‌:支持用户自定义数据类型、函数、操作符、索引方法等。
  • 高级特性‌:支持多版本并发控制(MVCC)、全文本搜索、地理空间数据处理(如PostGIS)、数据分区、流复制和高可用性等。

二、安装和配置

下面以Windows环境为例,一步一步展示PostgreSQL的安装和配置过程。

1、下载安装包

下载PostgreSQL-17.2-2 Windows安装包,也可去从官网下载,将下载的安装包放入本地目录。

2、安装PostgreSQL

鼠标右击安装文件,选择以管理员身份运行,并根据安装向导完成安装。

3、初始化PostgreSQL数据库

a、以管理员身份运行cmd.exe,打开命令行窗口:

b、在命令行窗口执行如下命令进行数据库初始化(实际路径请根据安装目录进行修改):

initdb.exe -D "D:\PostgreSQL\17\data"

c、注册服务:

pg_ctl.exe register -N "pgsql-17.2-2" -D "D:\PostgreSQL\17\data" 

执行完成后,打开windows服务查看并启动对应的服务(如下图)

d、创建默认角色postgres

createuser.exe -s -r postgres

至此,PostgreSQL就安装配置完了,下节将介绍通过pgAdmin连接数据库的过程。

### 在 Windows CMD 中创建 PostgreSQL 数据库 为了在 Windows 的命令提示符 (CMD) 中成功创建一个新的 PostgreSQL 数据库,需遵循特定的操作流程。首先,确保已正确安装并配置好 PostgreSQL 环境[^1]。 #### 切换至 PostgreSQL 用户环境 由于 PostgreSQL 默认以 `postgres` 用户身份运行服务,因此建议通过命令行切换到该用户权限下执行后续操作。这可通过如下指令实现: ```batch runas /user:postgres cmd.exe ``` 此命令会弹出新的命令窗口,在其中拥有 postgres 用户的访问权限[^2]。 #### 初始化数据库集群(如果尚未初始化) 对于初次设置或者新版本升级后的首次启动,可能需要先建立数据库集群。使用 initdb 命令完成这项工作: ```batch "C:\Program Files\PostgreSQL\{version}\bin\initdb.exe" -D "C:\Path\To\DataDirectory" ``` 注意替换 `{version}` 及路径为你实际安装位置和期望的数据存储目录。 #### 创建新数据库实例 一旦处于合适的用户上下文中,并确认数据库集群已经就绪,则可以直接调用 createdb 实用程序来定义新的数据库名称: ```batch createdb my_new_database_name ``` 上述命令将在默认模板基础上构建名为 `my_new_database_name` 的全新空白数据库结构[^3]。 #### 验证创建结果 最后一步是验证刚刚创建的新数据库是否存在以及能否正常访问。可以利用 psql 工具进入交互模式查询现有数据库列表: ```batch psql -l ``` 这条语句将会显示当前服务器上所有的可用数据库集合,其中包括刚添加的那个条目。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jackiendsc

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值