码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 关系数据库-postgresql-基础


    文章目录

    • 介绍
    • linux下安装
    • postgresql源码安装
    • navicat连接

    介绍

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

     

    linux下安装

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

     

    postgresql源码安装

    这里以CentOS为例:

    1. 源码下载地址,选择一个版本;
    2. 解压文件;
    # 解压到指定的目录
    tar -zxvf postgresql-12.8.tar.gz -C /home/laufing
    
    • 1
    • 2
    1. 进入到解压目录,配置
    cd  postgresql-12.8
    
    # 创建目录
    mkdir /usr/local/pgsql  # root 用户
    # 安装依赖
    yum install -y gcc readline-devel zlib-devel
    # 配置
    ./configure --prefix=/usr/local/pgsql  # 配置安装目录
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    1. 编译安装
    # 并行编译
    make -j8
    # 安装
    make install 
    #PostgreSQL installation complete.
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    1. 配置环境变量
    # root 用户配置/etc/profile
    # 一般用户配置 .bashrc
    
    export PATH=/usr/local/pgsql/bin:$PATH
    export LD_LIBRARY_PATH=/usr/local/pgsql/lib:$LD_LIBRARY_PATH
    
    • 1
    • 2
    • 3
    • 4
    • 5

    source /etc/profile 使文件生效

    1. 如果是root用户,安装好后是不允许以root身份运行数据库服务的,需要创建一个普通用户。
    # 添加一个普通用户
    # -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
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    1. 初始化数据库,并配置
    # 从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
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    1. 启动数据库
    pg_ctl -D /home/laufing/pgsql/data -l logfile start
    # stop or restart
    
    • 1
    • 2
    1. 客户端连接,并创建管理账户、普通账户
    # 连接 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 退出
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

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

     

    navicat连接

    1. 运行postgres、pg_ctl程序必须是普通用户(不能root用户)
    2. 使用创建的数据库普通用户,进行连接。
      在这里插入图片描述
       

  • 相关阅读:
    KWin全解析 —— overview.md(1)
    php 进程通信系列 (四)共享内存
    vue3——element-plus 实现页面刷新之后,保持菜单的激活状态
    计算机毕业设计ssm千益校园帮跑腿信息平台5e9ev系统+程序+源码+lw+远程部署
    Qt+ECharts开发笔记(五):ECharts的动态排序柱状图介绍、基础使用和Qt封装Demo
    [附源码]java毕业设计房屋租赁管理系统
    【牛客-剑指offer-数据结构篇】JZ23 链表中环的入口结点 两种实现 Java实现
    瑞芯微开发板资料收集
    大一学编程怎么学?刚接触编程怎么学习,有没有中文编程开发语言工具?
    项目中根据excel文件生成json多语言文件
  • 原文地址:https://blog.csdn.net/weixin_45228198/article/details/133924639
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号