首页 > 数据库 >【PostgreSQL】安装及创建空间数据库

【PostgreSQL】安装及创建空间数据库

时间:2024-09-12 11:49:23浏览次数:12  
标签:PostgreSQL 创建 数据库 pg 空间 using

简介

PostgreSQL 是一个功能强大的开源对象关系数据库系统

下载地址

PostgreSQL: Downloads

由于我电脑上安装的是arcgispro3.1所以需要下载对应的postgresql版本

PostgreSQL 12 对应的 PostGIS 版本主要是 3.5.0 或更高版本。

安装

一般设置为postgresql

安装扩展插件

此处就是告诉你是否需要下载额外的插件

扩展的详情介绍请查看

【PostgreSQL】扩展插件介绍-CSDN博客

我选择npsql是因为我需要用.net连接数据库

而且下边也有介绍

PostgreSQL的。net数据提供程序。由EnterpriseDB打包。

选择postgis是应为需要连接arcgis/geoscene/qgis,将空间数据进行上传到数据库

PostGIS“在空间上启用”PostgreSQL服务器,允许它被用作地理信息系统(GIS)的后端空间数据库。

等待下载

下载完成

安装.net数据库驱动

完成扩展

安装PostGis扩展

此处输入的是PostgreSQl数据库的密码postgresql

设置空间数据库的名称

安装

安装完成

扩展全部安装完成

操作

连接postgresql

创建数据库

Navicat操作PostgreSql

连接

创建空间数据库

创建成功,有tiger和tiger_data和topolpgy说明创建的是带有空间属性的数据库

在PostgreSQL中创建数据库时,确实会自动创建一个名为public的模式。这个模式是每个新数据库默认包含的,无论用户是否指定模式名称,PostgreSQL都会将其放入public模式中。

在PostgreSQL数据库中,"tiger"和"tigerdata"以及"topology"模式分别有其特定的用途和背景。

TIGER(Topologically Integrated Geographic Encoding and Referencing)是一个由美国人口普查局开发的地理编码系统。它是一个数字化(计算机可读)的地理数据库,用于支持人口普查和调查程序中的地图制作及相关地理活动。TIGER 数据库的内容通过各种“TIGER 提取”文件提供给公众,并且不断更新。

在PostGIS中,可以生成一个shell脚本,用于下载TIGER数据并将其暂存到名为tiger_data的模式中。每个州的脚本都会作为单独的记录返回。这表明tiger_data模式是专门用来存储从TIGER数据库中提取的数据的逻辑层面数据集合。

PostgreSQL中的topology模式包含用于创建拓扑结构的函数及拓扑目录表。如果该模式不存在,则说明尚未安装相关的扩展。拓扑结构在地理信息系统(GIS)中非常重要,用于描述空间对象之间的拓扑关系。

综上所述,tigertiger_data模式主要用于处理和存储与地理信息相关的数据,而topology模式则用于构建和管理复杂的拓扑结构。这些模式在PostgreSQL数据库中扮演着重要的角色,特别是在地理空间数据分析和处理中。

表空间介绍

表空间可以分为系统表空间和非系统表空间。系统表空间如SYSTEMSYSAUX用于存储系统数据,而非系统表空间用于存储用户数据。

在PostgreSQL中,表空间实际上是为表指定一个存储目录。创建表空间时可以指定存储位置,并在创建数据库时指定默认的表空间。

在PostgreSQL中,可以通过创建不同的表空间来管理不同类型的数据。

在PostgreSQL中,pg_globalpg_default是两个默认的表空间,它们在数据库初始化时自动创建。以下是它们的详细描述:

  1. pg_global

    • pg_global表空间用于存储共享的系统目录对象。这些对象是所有数据库共享的系统表,例如pg_databasepg_authid等。
    • 它的物理文件位置通常在数据目录的global目录中。
    • pg_global表空间是全局的,适用于所有数据库。
  2. pg_default

    • pg_default表空间是默认的表空间,用于存储用户创建的对象,如用户表、用户表索引、临时表、临时表索引等。
    • 它是template1template0数据库的默认表空间,因此也是其他数据库的默认表空间,除非在创建数据库时通过TABLESPACE子句指定其他表空间。
    • 它的物理文件位置通常在数据目录的base目录中。
    • pg_default表空间是每个数据库的默认存储位置,除非用户明确指定其他表空间。

总结来说,pg_global主要用于存储系统级的共享数据,而pg_default则是用户数据和默认对象的存储位置。这两个表空间在PostgreSQL的体系结构中扮演着关键角色,确保了系统数据和用户数据的分离与管理。

使用ArcGIS/GeoScenePro连接

配置

arcgispro路径

D:\Program Files\GeoScene\Pro\Resources\DatabaseSupport\GeoScenePro_41_ST_Geometry\PostgreSQL\12

 postgresql路径

D:\Program Files\PostgreSQL\12\lib

创建企业级地理数据

连接

连接成功

使用C#连接数据库

代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Npgsql;

namespace ConnectDatabase
{
    internal class Program
    {
        static void Main(string[] args)
        {
            // 连接字符串,包含了数据库的位置,用户名和密码
            string connString = "Host=localhost;Username=postgres;Password=postgresql;Database=GeoData";

            // 使用using语句确保连接会被正确关闭和释放
            using (var conn = new NpgsqlConnection(connString))
            {
                conn.Open();

                // 创建一个SQL查询
                string sql = "SELECT version()";

                using (var cmd = new NpgsqlCommand(sql, conn))
                {
                    // 执行查询并读取结果
                    var version = cmd.ExecuteScalar();
                    Console.WriteLine($"PostgreSQL version: {version}");
                }
            }
            Console.ReadKey();
        }
    }
}

连接成功

参考文档

PostgreSQL关系型数据库安装教程 (qq.com)

 数据库连接时的表空间 (metaso.cn)

pg_global 和 pg_default (metaso.cn) 

标签:PostgreSQL,创建,数据库,pg,空间,using
From: https://blog.csdn.net/qq_39397927/article/details/142145437

相关文章

  • thinkphp5数据库迁移工具 migration(longtext/tinyint等)
    我用tp5创建文件phpthinkmigrate:createUser在User文件里面写publicfunctionup(){$this->table('a3')->addColumn('a','integer',['limit'=>'10','default'=>0,'signed'=&......
  • openGauss和PostgreSQL差异对比
    检查点在PostgreSQL中的检查点叫全量检查点,执行时会将buffer中的所有的脏页刷到磁盘,需要在一定时间内完成刷脏页的操作,导致数据库运行性能波动较大。同时全量检查点开始时需要遍寻内存中的所有脏页,内存越大,寻找脏页的时间也越长,具体过程如下:遍历所有BUFFER,将当前时刻的所有脏块状态......
  • 数据库太慢跑崩的另一罪魁
    没错,就是著名的JOIN。JOIN一直是数据库计算的老大难问题,业界想了很多办法来计算它。如果不做任何优化,那就是两个关联表循环遍历,这是个乘法级的复杂度,数据量稍大一点就受不了。成熟的数据库当然不会这么傻,对于最常见的等值JOIN(关联条件为键值相等),通常会采用HASHJOIN的办......
  • 在线考试|基于java的模拟考试系统小程序(源码+数据库+文档)
    在线考试|模拟考试系统|模拟考试系统小程序目录基于java的模拟考试系统小程序一、前言二、系统设计三、系统功能设计四、数据库设计 五、核心代码 六、论文参考七、最新计算机毕设选题推荐八、源码获取:博主介绍:✌️大厂码农|毕设布道师,阿里云开发社区乘风者计划专......
  • 健身房|基于springboot的健身房管理系统设计与实现(附项目源码+论文+数据库)
    私信或留言即免费送开题报告和任务书(可指定任意题目)目录一、摘要二、相关技术三、系统设计四、数据库设计     五、核心代码      六、论文参考 七、源码获取  一、摘要随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步......
  • 网上请假|基于springboot的学生网上请假系统设计与实现(附项目源码+论文+数据库)
    私信或留言即免费送开题报告和任务书(可指定任意题目)目录一、摘要二、相关技术三、系统设计四、数据库设计   五、核心代码      六、论文参考 七、源码获取  一、摘要随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟......
  • 数据库tips16
    (九)、E-R图在设计E-R图的过程中,首先应该确定相关的实体,即将所有对象进行分类:然后根据各类确定的实体,找出每一实体应具有的属性,这一过程称为聚集;再从相关实体中抽象出子类和父类,这一过程称为概括。面向不同的应用,设计E-R图,在构建实体时只需要考虑应用中所需要的属性。因此,面向不同......
  • 基于springboot学生用品采购管理系统,附源码+数据库+论文+开题报告,包安装调试
    1、项目介绍......
  • Java数据库轮询
    在Java中,数据库轮询(DatabasePolling)通常指的是定期查询数据库以检查是否有新的数据或者数据状态的变化。这种方式在某些场景下是有用的,比如在需要实时监控数据库变化的应用中。不过,轮询并不是一种高效的解决方案,因为它可能会导致不必要的资源消耗,特别是在没有变化发生的时候。以......
  • Springboot大连和平广场停车场管理系统52oca程序+源码+数据库+调试部署+开发环境
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容一、研究背景随着城市化进程的加快和私家车数量的激增,大连和平广场等繁华商业区域的停车难问题日益凸显。传统的人工停车场管理方式效率低下,难以满......