PostgreSQL学会如何建表

article/2025/8/28 3:11:03

开始使用PostgreSQL之前, 上一节我们说了怎样安装它。

PostgreSQL可能已经安装到你的电脑上了,安装后postgre服务默认在电脑开机时运行启动。

一.了解PostgreSQL的运行

PostgreSQL使用一种客户端/服务器(C/S)模型。

和其他典型的客户端/服务器应用一样,客户端和服务器可以在不同的主机上,这时它们通过 TCP/IP 网络连接通讯。

1.客户端应用是多种多样的,你可以使用很多的工具来连接上它。我们使用的现在有两种 pgAdmin 和 sql命令行工具。

        1.1 pgAdmin

        1.2 sql命令行工具

2.服务器有一个守护进程总是在等待着客户端来连接。

    当一个客户端连接时会运行一个服务器进程,多个客户端连接时会分别对应运行多个服务器进程。

    所以说一次连接就是建立了一次PostgreSQL会话,会话可以是长时的,就是说一个会话可以分别执行多个sql命令。

3.每一个服务器进程,管理数据库文件、接收客户端与数据库的连接,并且代表客户端在数据库上执行操作。

    数据库服务器程序就叫做postgres,这是它的由来。

二.创建一个数据库

首先通过默认用户postpre登录。

一个新的数据库,在我们例子数据库叫 firstdb ,可以使用下面的命令:

create database firstdb; --创建名称为firstdb的数据库

注意创建数据库需要;结尾

如果不产生任何响应则表示该步骤成功。

注意新的数据库,默认可以使用超级用户postgre登录,我们就使用超级用户postgre重新连接新数据库firstdb。

之后试验一下下面的命令:

select version(); -- 输出当前数据库版本信息

select current_date; -- 打印当前日期

select 2 + 2; -- 计算2+2

两个方式执行,哪个都行。

如果使用的是sql命令行工具,psql程序有一些不属于SQL命令的内部命令,以反斜线开头 \,获取各种SQL命令的帮助语法:

  • \h 表示帮助语法 help

   

     firstdb=> \h

  • \q 表示退出psql

       

 firstdb=> \q

三.SQL语言说明


PostgreSQL是一种关系型数据库管理系统(RDBMS)。是一种用于管理存储在关系中的数据的系统。关系是表的数学术语。

现今把数据存储在表里的概念已经快成了固有的常识。

1.单个PostgreSQL服务器实例管理的全部数据库的集合,组成了一个数据库集簇。

2.一个数据库可以分组为多个表,可以与excel表格类比。

3.每个表都是一个行集合,每一行由一组命名列组成,而每一列都有一个特定的数据类型。

四.创建表天气表

指定表的名字weather(天气) 和所有列的名字及类型来创建一个表∶

 

create table weather ( --创建表天气id varchar(20), --id为表的行标识id 1、2、3、4.... varchar(20)为字符数据类型,最大20个字符city varchar(80), -- 城市名词 varchar(80) 为存储最长80个字符的任意字符串的数据类型temp_low int, -- 最低温度 int是整数类型temp_high int, -- 最高温度 int是整数类型prcp real, -- 湿度 real存储单精度浮点数的类型(知道就行,不常用)date date -- 时间字段 就是类型为date的列名字也是date
);
 

-- 这个标志为注释,就是说明,在sql中不会进行执行,会被忽略。

上面的sql命令以及换行符,直到分号才结束。

在 SQL 命令中可以自由使用空白(即空格、制表符和换行符)。

SQL 是对关键字和标识符大小写不敏感的语言。

PostgreSQL支持标准的SQL类型有int、smallint、real、double precision、char(N)、varchar(N)、date、time、timestamp和interval,还支持其他的通用功能的类型和丰富的几何类型。

甚至可以定制任意数量的用户自定义数据类型。因而类型名并不是语法关键字,除了SQL标准要求支持的特例外。

五.创建表城市表

用来保存城市和相关的地理位置:

create table cities ( --创建表城市id varchar(20), --id为表的行标识id varchar(20)为字符数据类型,最大20个字符name varchar(80), --name为城市名称 varchar(80) 为存储最长80个字符的任意字符串的数据类型location point --location地理位置字段 类型point就是一种PostgreSQL特有数据类型的例子(知道就行,不常用)
);

 

看了两个表的创建应该明白了,它的形式都一样,就看我们存储什么。

六.删除城市表

如果你不再需要某个表,或者以不同的形式要重建它,那么你可以用下面的命令删除对应的表。

drop table cities; -- drop 执行会删除表,删除后无法恢复

甚至可以直接删除刚新建的数据库firstdb

drop database firstdb; -- 删除数据库(DROP DATABASE 大小写都有)

当前登录为firstdb数据库,自己不能删除自己的库。

若真要删除可以登录postgres用户删除,因为建库是用postgres用户。

最后

下次说表中增加行和查询表

完毕!


http://www.hkcw.cn/article/meXGjubbnQ.shtml

相关文章

Wirtinger Flow算法的matlab实现和python实现

文章目录 1. 数学模型2. Wirtinger Flow 算法2.1. 光谱初始化方法2.2. Wirtinger梯度下降 3. 算法实现3.1. Matlab实现3.2. Python实现 参考文献 1. 数学模型 观测数学模型可由下面公式给出 y ∣ A x ∣ 2 y |Ax|^2 y∣Ax∣2 其中 x ∈ C n x\in\mathbb C^{n} x∈Cn&#x…

QT+opecv如何更改图片的拍摄路径

如何更改相机拍摄图片的路径 前言:基础夯实:效果展示:实现功能:遇到问题:未解决: 核心代码: 前言: 最近在项目开发中遇到需要让用户更改相机拍摄路径的问题,用户可自己选…

常见的国密加密算法(M1/M2/M3/M4)

国密加密算法 SM2(非对称加密算法) 类型:是非对称加密算法,基于椭圆曲线密码实现。特点:包括有数字签名算法、密钥交换协议,公钥加密算法等部分,其中256位的安全强度比RSA 2048位高,但运算速度更快。使用…

Ubuntu系统下Docker部署Dify保姆级教程:实现内网穿透远程访问

文章目录 前言1. Docker部署Dify2. 本地访问Dify3. Ubuntu安装Cpolar4. 配置公网地址5. 远程访问6. 固定Cpolar公网地址7. 固定地址访问 前言 各位开发者朋友,今天我们将开启一项创新实践——基于Ubuntu系统搭建Dify大语言模型开发平台,并通过Docker容器…

MySQL高可用革命:Orchestrator实现零干预的故障转移与智能拓扑管理

MySQL高可用革命:Orchestrator实现零干预的故障转移与智能拓扑管理 凌晨3点,某电商平台的数据库主节点突然宕机,而系统却在30秒内自动切换至备用节点,数百万用户的购物车数据完好无损——这一切的背后,正是Orchestrato…

Github 2025-05-29 Go开源项目日报Top9

根据Github Trendings的统计,今日(2025-05-29统计)共有9个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Go项目9Assembly项目1Ollama: 本地大型语言模型设置与运行 创建周期:248 天开发语言:Go协议类型:MIT LicenseStar数量:42421 个Fork数量:27…

技能造血破冰中年人就业困局:粤荣职业培训学校与康安堂共筑康养人才直通车

2025年5月28日,广州市白云区粤荣职业培训学校与康安堂(广州)健康产业有限责任公司在广州市白云区正式签署就业合作协议。在当前社会,中年人就业难问题日益凸显。他们面临着家庭和社会的双重压力,却因年龄、技能等因素在就业市场上处于劣势。粤…

notion搭建个人知识管理库

nullhttps://www.bilibili.com/video/BV1Ur4y1L77m/?spm_id_from333.337.search-card.all.click&vd_source5434ba52b45e69a8650762bf71d67608 一、视频教程:如何搭建个人管理数据库,包括目标管理、知识管理、任务管理等功能,以及如何创建表格和设置…

EC800X QuecDuino开发板介绍

支持的模组列表 EG800KEC800MEC800GEC800E 功能列表 基本概述 EC800X QuecDuino EVB 搭载移远 EC800 系列模组。支持模组型号为: EC800M 系列、EC800K 系列、EG800K 系列、EC800E 系列等。 渲染图 开发板的主要组件、接口布局见下图 资料下载 EC800X-QuecDui…

CC攻击的种类与特点解析

CC攻击(Challenge Collapsar)是一种针对Web应用层的分布式拒绝服务(DDoS)攻击,通过模拟合法用户请求耗尽服务器资源,导致服务不可用。以下是其核心种类及特点的详细分析: 一、CC攻击的种类 代理…

Vite打包优化实践:从分包到性能提升

前言: ​​​​​​​ 随着前端应用功能的增加,项目的打包体积也会不断膨胀,影响加载速度和用户体验。本文介绍了几种常见的打包优化策略,通过Vite和相关插件,帮助减少项目体积、提升性能,优化加载速度。 rollup-plugi…

深度解析 9 大 UI 设计风格

1. 扁平化设计 (Flat Design) 特点: 简洁明了: 移除了阴影、渐变、纹理等三维效果,强调二维平面元素。色彩鲜明: 常用大胆、明亮的色彩。极简主义: 专注于功能性,减少不必要的装饰。排版清晰: 强调大字体和清晰的文本。易于响应: 扁平化设计在不同屏幕尺…

信号与系统速成-1.绪论

b站浙大教授虽然讲的比较细,但是太慢了,不适合速成 祖师爷奥本海姆的MIT课程好像和我们教材的版本不太匹配,但是讲的很不错 慕课上也有很多资源,比如信号与系统 - 网易云课堂 同站博主篱笆外的xixi的文章也挺不错 最终我还是选…

WPF prism

Prism Prism.Dryloc 包 安装 Nuget 包 - Prism.DryIoc 1. 修改 App.xaml 修改 App.xaml 文件&#xff0c;添加 prism 命名空间, 继承由 Application → PrismApplication&#xff0c;删除默认启动 url, StartupUri“MainWindow.xaml” <dryioc:PrismApplicationx:Class…

Shell 脚本

注&#xff1a;文章参考《鸟哥的linux私房菜》、通义千问AI产品 认识 Shell Linux 中的 Shell 就是 linux 内核的一个外层保护工具&#xff0c;并负责完成用户与内核之间的交互。 Shell 可以分为以下几类&#xff1a; Bourne Shell &#xff08;简称 sh&#xff09;C Shell…

Win11安装Dify

1、打开Virtual Machine Platform功能 电脑系统为&#xff1a;Windows 11 家庭中文版24H2版本。 打开控制面板&#xff0c;点击“程序”&#xff0c;点击“启用或关闭Windows功能”。 下图标记的“Virtual Machine Platform”、“适用于 Linux 的 Windows 子系统”、“Windows…

自动化立体仓库堆垛机SRM控制系统FC19手动控制功能块开发

1、控制系统手动控制模块HMI屏幕设计如下图 屏幕分为几个区域:状态显示区、控制输入区、导航指示区、报警信息区。状态显示区需要实时反馈堆垛机的位置、速度、载货状态等关键参数。控制输入区要有方向控制按钮,比如前后左右移动,升降控制,可能还需要速度调节的滑块或选择按…

软件无线电技术之基带QPSK 调制技术+扩频技术

基带QPSK 调制技术 数字正交调制以0、1 比特流为调制信号&#xff0c;其过程就是将原始数据按照一定的规则映射至IQ 坐标系&#xff0c;而后经过DAC 转为模拟信号后才能进行后续的IQ 调制。 数字IQ 调制完成了符号到矢量坐标系的映射&#xff0c;映射点一般称为星…

图像数据与显存

一、 图像数据的介绍 1.1 灰度图像 从这里开始我们进入到了图像数据相关的部分&#xff0c;也是默认你有之前复试班计算机视觉相关的知识&#xff0c;但是一些基础的概念我仍然会提。 昨天我们介绍了minist这个经典的手写数据集&#xff0c;作为图像数据&#xff0c;相较于结…

opencut:如何用AI工具把中文图片/视频翻译成英语、日语、俄语等100多种语言!

在全球化背景下&#xff0c;无论是学习、工作还是生活&#xff0c;多语言翻译需求日益增长。从跨境电商产品图的本地化适配&#xff0c;到学习资料的快速翻译&#xff0c;传统人工翻译不仅成本高、耗时长&#xff0c;还可能因文化差异导致误解。 今天为大家分享一款高效实用的 …