关系数据库-postgresql-基础

文章目录

介绍

  1. Postgresql官网
  2. 开源的关系型数据库;

linux下安装

  1. Ubuntu下可以使用apt包管理器安装;参考地址
  2. CentOS下可以使用yum包管理器安装;
  3. OpenSuse下可以使用zypper包管理器安装;参考地址
  4. 使用包管理器有时安装不到较新的版本,可以选择源码安装;

postgresql源码安装

这里以CentOS为例:

  1. 源码下载地址,选择一个版本;
  2. 解压文件;
bash 复制代码
# 解压到指定的目录
tar -zxvf postgresql-12.8.tar.gz -C /home/laufing
  1. 进入到解压目录,配置
bash 复制代码
cd  postgresql-12.8

# 创建目录
mkdir /usr/local/pgsql  # root 用户
# 安装依赖
yum install -y gcc readline-devel zlib-devel
# 配置
./configure --prefix=/usr/local/pgsql  # 配置安装目录
  1. 编译安装
bash 复制代码
# 并行编译
make -j8
# 安装
make install 
#PostgreSQL installation complete.
  1. 配置环境变量
bash 复制代码
# root 用户配置/etc/profile
# 一般用户配置 .bashrc

export PATH=/usr/local/pgsql/bin:$PATH
export LD_LIBRARY_PATH=/usr/local/pgsql/lib:$LD_LIBRARY_PATH

source /etc/profile 使文件生效

  1. 如果是root用户,安装好后是不允许以root身份运行数据库服务的,需要创建一个普通用户。
bash 复制代码
# 添加一个普通用户
# -d 指定家目录 -m 自动创建家目录
# -g 组
# -s 使用的shell
useradd jack -d /home/jack -m -g root -s /bin/bash

# 设置密码
passwd jack
xxxxx

# 更改pgsql所属用户
chown -R jack:root /usr/local/pgsql
  1. 初始化数据库,并配置
bash 复制代码
# 从root切换到普通用户
su - jack
# 初始化db,初始化完成会生成配置文件等
mkdir /home/jack/pgsql/data
initdb -D /home/jack/pgsql/data  

# 配置
vim data/postgresql.conf
listen_addresses = "*"
port = 5432
bytea = "escape"

vim postgresql_hba.conf
# 添加
host all all 0.0.0.0/0 md5
  1. 启动数据库
bash 复制代码
pg_ctl -D /home/laufing/pgsql/data -l logfile start
# stop or restart
  1. 客户端连接,并创建管理账户、普通账户
bash 复制代码
# 连接 postgres 数据库
psql -U jack -d postgres

# 创建管理账户
create user dba password  'dba' superuser createrole createdb;
grant jack to dba;   

# 创建普通用户
create user lauf with password 'lauf';
create database test owner lauf;
grant all privileges on database test to lauf;

# 
\l 查看所有的库
\d 查看当前库所有的表
\d stu_t  查看表结构
\q 退出
exit 退出

使用navicat 连接postgresql数据库, 源码安装完成。

  1. 运行postgres、pg_ctl程序必须是普通用户(不能root用户)
  2. 使用创建的数据库普通用户,进行连接。
相关推荐
丶意冷18 分钟前
mybatisPlus分页方言设置错误问题 mybatisPlus对于Oceanbase的Oracle租户分页识别错误
java·数据库·oracle·oceanbase
时序数据说2 小时前
为什么时序数据库IoTDB选择Java作为开发语言
java·大数据·开发语言·数据库·物联网·时序数据库·iotdb
戒不掉的伤怀2 小时前
【Navicat 连接MySQL时出现错误1251:客户端不支持服务器请求的身份验证协议;请考虑升级MySQL客户端】
服务器·数据库·mysql
cv高级工程师YKY2 小时前
服务器 - - QPS与TPS介绍
数据库
nbsaas-boot2 小时前
高可扩展属性建模设计:架构师的全局思考与落地方案
数据库
爱上语文3 小时前
Redis基础(5):Redis的Java客户端
java·开发语言·数据库·redis·后端
陈敬雷-充电了么-CEO兼CTO3 小时前
推荐算法系统系列>推荐数据仓库集市的ETL数据处理
大数据·数据库·数据仓库·数据挖掘·数据分析·etl·推荐算法
MeshddY3 小时前
(超详细)数据库项目初体验:使用C语言连接数据库完成短地址服务(本地运行版)
c语言·数据库·单片机
wuxinyan1234 小时前
Java面试题033:一文深入了解MySQL(5)
java·数据库·mysql·面试
萧曵 丶4 小时前
Spring @TransactionalEventListener
java·数据库·spring·事务·transactional·异步