PostgreSQL在Linux环境下的常用命令总结
标题
- 登录PgSQL
- 库表基本操作命令
- 新建库表
- 修改库表
- 修改数据库名称:
- 修改表名称
- 修改表字段信息
- 删除库表
- pgsql删除正在使用的数据库
须知:
以下所有命令我都在Linux环境中执行验证过,大家放心食用,其中的实际名称换成自己的实际名称即可。而且这块如果你不是运维人员的话,你只需要简单的会在Linux下查一下数据就行了。其他的操作都在客户端工具操作比较简单。了解一下即可
关于客户端的操作命令可以点我查看
登录PgSQL
基本连接方式
psql -U <用户名> -d <数据库名>
:这是连接到指定数据库的常用命令。
例如,psql -U postgres -d mydb
表示以 postgres 用户身份连接到 mydb 数据库。
如果省略 -d 选项和数据库名,将连接到用户的默认数据库(postgres) 。
库表基本操作命令
- 查看数据库版本:
select version();
- #查看有哪些用户:
\dg
- 列出所有数据库:
\l
- 切换数据库:
\c mydb
- 列出当前数据库的所有表:
\dt
- 列出表的结构:
\d 表名
- 列出所有角色:
\du
- 修改用户名密码:postgres=#
alter user postgres with password 'postgres';
-- 创建新数据库
CREATE DATABASE 数据库名;-- 删除数据库
DROP DATABASE 数据库名;-- 创建新表
CREATE TABLE 表名 (列1 数据类型,列2 数据类型,...
);-- 删除表
DROP TABLE 表名;-- 插入数据
INSERT INTO 表名 (列1, 列2, ...) VALUES (值1, 值2, ...);-- 更新数据
UPDATE 表名 SET 列1 = 值1, 列2 = 值2 WHERE 条件;-- 删除数据
DELETE FROM 表名 WHERE 条件;-- 查询数据
SELECT * FROM 表名;-- 创建新用户
CREATE USER 用户名 WITH PASSWORD '密码';-- 修改用户密码
ALTER USER 用户名 WITH PASSWORD '新密码';-- 为用户授权
GRANT 权限 TO 用户名;-- 撤销权限
REVOKE 权限 FROM 用户名;
新建库表
以下是在 PostgreSQL 中创建数据库 mydb 以及在其中创建 student 表和 teacher 表,并为每个表添加一些测试用字段的示例代码:
-- 创建数据库mydb
CREATE DATABASE mydb;-- 连接到新创建的数据库mydb
\c mydb-- 创建student表
CREATE TABLE student (student_id SERIAL PRIMARY KEY,student_name VARCHAR(50),student_age INTEGER,student_gender CHAR(1),major VARCHAR(100)
);-- 创建teacher表
CREATE TABLE teacher (teacher_id SERIAL PRIMARY KEY,teacher_name VARCHAR(50),teacher_age INTEGER,subject VARCHAR(100),department VARCHAR(100)
);-- 向student表插入第一条数据
INSERT INTO student (student_name, student_age, student_gender, major)
VALUES ('张三', 20, 'M', '计算机科学与技术');-- 向student表插入第二条数据
INSERT INTO student (student_name, student_age, student_gender, major)
VALUES ('李四', 22, 'F', '软件工程');-- 向teacher表插入第一条数据
INSERT INTO teacher (teacher_name, teacher_age, subject, department)
VALUES ('王老师', 35, '数据库原理', '计算机系');-- 向teacher表插入第二条数据
INSERT INTO teacher (teacher_name, teacher_age, subject, department)
VALUES ('李老师', 40, '操作系统', '计算机系');
修改库表
修改数据库名称:
一般来说没这种需求,不过测试玩玩的话还是整理一下吧
方法一
备份sql(见下面说明)
切换到别的数据库下删除:DROP DATABASE mydb;
CREATE DATABASE mybdtest;
执行备份SQL进行回复(见下面说明)
备份数据库(使用pg_dump)
在 Linux 下,备份mydb数据库可以使用pg_dump命令。假设你的 PostgreSQL 数据库用户名是postgres,密码是your_password(请替换为实际密码),主机地址是localhost,数据库名是mydb,你可以使用以下命令将数据库备份为一个.sql文件:
pg_dump -U postgres -h localhost -Fc mydb > mydb_backup.dump
命令解释:
-U postgres
:指定以postgres用户身份进行备份操作。
-h localhost
:指定数据库主机地址为本地(localhost),如果数据库在远程服务器,需要替换为实际的远程主机地址。
-Fc
:指定输出格式为自定义(custom)二进制格式,这种格式在恢复数据时比较高效。如果想要纯文本格式的备份文件,可以使用-Fp(plain text),不过恢复时可能会稍微复杂一点。
mydb
:要备份的数据库名称。
> mydb_backup.dump
:将备份内容输出到名为mydb_backup.dump的文件中,你可以根据自己的喜好更改文件名。
恢复数据库(使用pg_restore)
在删除mydb并创建mybdtest后,使用pg_restore命令来恢复备份的数据到mybdtest数据库。假设你的用户名、主机地址等信息不变,执行以下命令:
pg_restore -U postgres -h localhost -d mybdtest mydb_backup.dump
命令解释:
-U postgres:指定以postgres用户身份进行恢复操作。
-h localhost:指定数据库主机地址为本地。
-d mybdtest:指定恢复数据的目标数据库为mybdtest。
mydb_backup.dump:要恢复的备份文件的名称,需要与备份时的文件名一致。
需要注意的是,在执行这些命令时,可能需要确保postgres用户有足够的权限进行备份和恢复操作。如果数据库设置了密码,可能还需要在命令中正确提供密码,或者设置PGPASSWORD环境变量来存储密码,这样就不用每次在命令中输入密码了。例如,可以在执行命令前设置环境变量:export PGPASSWORD=your_password
方法二
使用 ALTER DATABASE(在某些特定版本和场景下可能有限制)
在一些较新的 PostgreSQL 版本中,理论上可以尝试使用 ALTER DATABASE 语句来更改数据库名称,但这种方法可能会受到一些限制,比如数据库的使用状态、权限等因素可能会影响其成功与否。
假设你在 psql 命令行环境下并且有足够的权限,你可以尝试以下操作:
ALTER DATABASE mydb RENAME TO mybdtest;
如果此操作成功,那么数据库名称就直接被更改为 mybdtest 了。但如果遇到错误,可能就需要按照方法一的步骤来完成更名操作啦。
需要注意的是,无论使用哪种方法,在进行这些操作之前,都建议你先对重要数据进行备份,以防出现意外情况导致数据丢失。
修改表名称
要将表名 student 修改为 student_info,可以使用 ALTER TABLE 语句来实现。以下是具体的操作步骤:
-- 将表student修改为student_info
ALTER TABLE student RENAME TO student_info;
修改表字段信息
修改表字段名称、字段类型、字段注释
这块我有一篇博客根据各种情况都有对应的命令说明可以点我去看
一、修改列名
将 student_id 修改为 stu_id:
ALTER TABLE student_info RENAME COLUMN student_id TO stu_id;二、修改数据类型
将 student_name 的数据类型从 character varying(50) 修改为 character(20):
ALTER TABLE student_info ALTER COLUMN student_name TYPE character(20);三、修改数据类型及注释
先将 student_gender 的数据类型从 character(1) 修改为 integer:
# ALTER TABLE student_info ALTER COLUMN student_gender TYPE integer;
如果执行上面sql一定会报错的,因为上面这种情况只适合修改前后数据类型一致的情况,需要执行下面sql,
但是不保证一定成功,除非你存储的数据能成功转换为目标类型,像我实践中就报错,所以要保证数据的合理性ALTER TABLE student_info
ALTER COLUMN student_gender TYPE integer
USING CAST(student_gender AS integer);然后为 student_age 添加注释 “学生年龄”。在 PostgreSQL 中,添加列注释可以使用 COMMENT ON COLUMN 语句:
COMMENT ON COLUMN student_info.student_age IS '学生年龄';完成上述操作后,你可以再次使用 \d student_info 命令来查看表结构的变化情况,此时表结构应该符合你修改后的要求。
\d student_info
关于看不见添加的注释问题原因分析:
\d student_info 命令来查看表结构。这个命令在某些数据库客户端中可能不会显示列注释。
你可以尝试使用以下查询语句来查看带有注释的表结构:
SELECT column_name, data_type, column_default, is_nullable, col_description((table_schema || '.' || table_name)::regclass,ordinal_position) AS comment
FROM information_schema.columns
WHERE table_schema = 'public' AND table_name = 'student_info';
这个查询会从 information_schema.columns 中获取列的详细信息,包括注释。
数据库配置或客户端问题
有些数据库客户端可能不支持显示注释,或者需要特定的设置才能显示注释。你可以检查一下你使用的数据库客户端的设置,看是否有相关选项可以启用注释显示。
注释未正确添加
虽然从截图中看到了添加注释的操作,但有可能由于某种原因(例如权限问题或数据库错误)导致注释没有成功添加。你可以尝试重新添加注释,然后使用上述查询语句来验证注释是否添加成功。
删除库表
一般来说直接 drop database mydb;
就可以删除掉数据库了,下面我们说下相关注意事项
执行这条命令之前要确保你当前没有连接到 mydb 数据库哦,不然也会报错无法删除的。
一般可以先通过 \c
命令切换到其他数据库(比如 postgres),然后再执行删除 mydb 的操作。
例如:
\c postgres
drop database mydb;
当前还有其他用户(或者其他会话)正在连接并使用 mydb 数据库时,是无法直接删除它的。
你可以通过以下几种方法来解决这个问题并成功删除 mydb 数据库:
方法一:终止其他正在使用的会话
首先,你需要查看当前正在使用 mydb 数据库的会话信息。可以使用以下查询语句(在 postgres 数据库下执行):
SELECT pid, usename, datname, application_name, client_addr, client_hostname, client_port FROM pg_stat_activity WHERE datname ='mydb';
这条查询语句会列出正在使用 mydb 数据库的会话的进程 ID(pid)、用户名(usename)、数据库名(datname)、应用程序名(application_name)、客户端地址(client_addr)、客户端主机名(client_hostname)以及客户端端口(client_port)等信息。
找到对应的会话进程 ID 后,你可以使用以下命令来终止该会话(需要有足够的权限,比如超级用户权限):
SELECT pg_terminate_backend(pid);
这里的 pid 就是你在上一步查询中找到的那个正在使用 mydb 数据库的会话的进程 ID。
终止所有正在使用 mydb 数据库的会话后,再尝试执行删除数据库的命令:
drop database mydb;
方法二:等待其他会话结束自行使用
如果你确定其他正在使用 mydb 数据库的会话会在不久后自行结束,你可以稍作等待,然后再重新尝试执行删除数据库的命令:drop database mydb;
不过这种方法可能不太确定需要等待多长时间,而且如果其他会话一直不结束,就无法顺利删除数据库啦。
pgsql删除正在使用的数据库
这个了解一下就行,也就测试阶段使用
-- 设置数据库禁止连接
UPDATE pg_database SET datallowconn = 'false' WHERE datname = 'db_name';
-- 中断当前所有连接会话
SELECT pg_terminate_backend(pid) FROM pg_stat_activity WHERE datname = 'db_name';
-- 删除数据库
drop database db_name;
相关文章:

PostgreSQL在Linux环境下的常用命令总结
标题 登录PgSQL库表基本操作命令新建库表修改库表修改数据库名称:修改表名称修改表字段信息 删除库表pgsql删除正在使用的数据库 须知: 以下所有命令我都在Linux环境中执行验证过,大家放心食用,其中的实际名称换成自己的实际名称即…...

Unity shaderlab 实现LineSDF
实现效果: 实现代码: Shader "Custom/LineSDF" {Properties{}SubShader{Tags { "RenderType""Opaque" }Pass{CGPROGRAM#pragma vertex vert#pragma fragment frag#include "UnityCG.cginc"struct appdata{floa…...
Ubuntu中的apt update 和 apt upgrade
apt update 和 apt upgrade 是 Debian 及其衍生发行版(如 Ubuntu)中常用的两个 APT 包管理命令,它们各自执行不同的任务: apt update: 这个命令用于更新本地软件包列表。当你运行 apt update 时,APT 会从配置的源&…...
Android 中 Swipe、Scroll 和 Fling 的区别
Android 中 Swipe、Scroll 和 Fling 的区别 Swipe(滑动)Scroll(滚动)Fling(甩动)三者之间的区别代码示例 (Fling)总结 在 Android 应用中,Swipe、Scroll 和 Fling 都是用户在触摸屏幕上进行的滑…...

linux基础2
声明! 学习视频来自B站up主 泷羽sec 有兴趣的师傅可以关注一下,如涉及侵权马上删除文章,笔记只是方便各位师傅的学习和探讨,文章所提到的网站以及内容,只做学习交流,其他均与本人以及泷羽sec团队无关&#…...

如何通过智能生成PPT,让演示文稿更高效、更精彩?
在快节奏的工作和生活中,我们总是追求更高效、更精准的解决方案。而在准备演示文稿时,PPT的制作往往成为许多人头疼的问题。如何让这项工作变得轻松且富有创意?答案或许就在于“AI生成PPT”这一智能工具的广泛应用。我们就来聊聊如何通过这些…...

执法记录仪数据自动备份光盘刻录归档系统
派美雅按需研发的执法记录仪数据自动备份光盘刻录归档系统,为用户提供数据自动上传到刻录服务端、数据上传后自动归类,全自动对刻录端视频文件大小进行实时监测,满盘触发刻录,无需人工干预。告别传统刻录存在的痛点,实…...

启动SpringBoot
前言:大家好我是小帅,今天我们来学习SpringBoot 文章目录 1. 环境准备2. Maven2.1 什么是Maven2.2 创建⼀个Maven项⽬2.3 依赖管理2.3.1 依赖配置2.3.2 依赖传递2.3.4 依赖排除2.3.5 Maven Help插件(plugin) 2.4 Maven 仓库2.6 中…...
重定向操作和不同脚本的互相调用
文章目录 前言重定向操作和不同脚本的互相调用 前言 声明 学习视频来自B站UP主 泷羽sec,如涉及侵权马上删除文章 笔记的只是方便各位师傅学习知识,以下网站只涉及学习内容,其他的都与本人无关,切莫逾越法律红线,否则后果自负 重定向操作和不同脚本的互相调用 1.不同脚本的互相…...

51单片机教程(九)- 数码管的动态显示
1、项目分析 通过演示数码管动态显示的操作过程。 2、技术准备 1、 数码管动态显示 4个1位数码管和单片机如何连接 a、静态显示的连接方式 优点:不需要动态刷新;缺点:占用IO口线多。 b、动态显示的连接方式 连接:所有位数码…...
golang支持线程安全和自动过期map
在 Golang 中,原生的 map 类型并不支持并发安全,也没有内置的键过期机制。不过,有一些社区提供的库和方案可以满足这两个需求:线程安全和键过期。 1. 使用 sync.Map(线程安全,但不支持过期) Go…...
机器学习之RLHF(人类反馈强化学习)
RLHF(Reinforcement Learning with Human Feedback,基于人类反馈的强化学习) 是一种结合人类反馈和强化学习(RL)技术的算法,旨在通过人类的评价和偏好优化智能体的行为,使其更符合人类期望。这种方法近年来在大规模语言模型(如 OpenAI 的 GPT 系列)训练中取得了显著成…...

泷羽sec---shell作业
作业一 写计算器 使用bc命令 需要进行安装bc 代码如下: #!/bin/bash echo "-----------------------------------" echo "输入 f 退出" echo "可计算小数和整数" echo "用法如:1.12.2" echo "------…...

华为海思2025届校招笔试面试经验分享
目前如果秋招还没有offer的同学,可以赶紧投递下面这些公司,都在补招。争取大家年前就把后端offer拿下。如果大家在准备秋招补录取过程中有任何问题,都可以私信小编,免费提供帮助。如果还有部分准备备战春招的同学,也可…...

摆脱复杂配置!使用MusicGPT部署你的私人AI音乐生成环境
文章目录 前言1. 本地部署2. 使用方法介绍3. 内网穿透工具下载安装4. 配置公网地址5. 配置固定公网地址 前言 今天给大家分享一个超酷的技能:如何在你的Windows电脑上快速部署一款文字生成音乐的AI创作服务——MusicGPT,并且通过cpolar内网穿透工具&…...
嵌入式Linux中的GPIO编程
GPIO(General Purpose Input Output)是嵌入式系统中非常常见的一种硬件资源,它允许开发者直接控制微处理器或微控制器的引脚。通过设置这些引脚的状态,可以实现对硬件设备的控制,如LED灯的开关、传感器数据的读取等。 …...

js:函数
函数 函数:实现抽取封装,执行特定任务的代码块,方便复用 声明 函数命名规范 尽量小驼峰 前缀应该为动词,如getName、hasName 函数的调用 函数体是函数的构成部分 函数传参 参数列表里的参数叫形参,实际上写的数据叫实…...

低代码平台审批流程设计
审批流程设计 在此界面设置审批单从发起、到审批、再到结束的流转步骤。 6.1 添加节点 点击两个节点间连线的 图标可添加 审批人、抄送人、办理人、条件分支。 6.2 节点类型 提交节点 点击提交节点,可在右侧弹窗中设置提交节点的抄送人,实现审批在发…...
OpenCV相机标定与3D重建(8)相机标定函数calibrateCamera()的使用
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 从校准图案的多个视图中找到相机的内参和外参参数. cv::calibrateCamera 是 OpenCV 中用于相机标定的一个非常重要的函数。它通过一系列已知的世…...
Linux信号量的编程
一,用信号量来实现是父进程先进行,还是子进程先进性 信号量的没有P,V操作之前,我们不知道如何控制: #include <stdio.h> #include <sys/types.h> #include <sys/ipc.h> #include <sys/sem.h>…...
web vue 项目 Docker化部署
Web 项目 Docker 化部署详细教程 目录 Web 项目 Docker 化部署概述Dockerfile 详解 构建阶段生产阶段 构建和运行 Docker 镜像 1. Web 项目 Docker 化部署概述 Docker 化部署的主要步骤分为以下几个阶段: 构建阶段(Build Stage):…...

MPNet:旋转机械轻量化故障诊断模型详解python代码复现
目录 一、问题背景与挑战 二、MPNet核心架构 2.1 多分支特征融合模块(MBFM) 2.2 残差注意力金字塔模块(RAPM) 2.2.1 空间金字塔注意力(SPA) 2.2.2 金字塔残差块(PRBlock) 2.3 分类器设计 三、关键技术突破 3.1 多尺度特征融合 3.2 轻量化设计策略 3.3 抗噪声…...
基于大模型的 UI 自动化系统
基于大模型的 UI 自动化系统 下面是一个完整的 Python 系统,利用大模型实现智能 UI 自动化,结合计算机视觉和自然语言处理技术,实现"看屏操作"的能力。 系统架构设计 #mermaid-svg-2gn2GRvh5WCP2ktF {font-family:"trebuchet ms",verdana,arial,sans-…...
R语言AI模型部署方案:精准离线运行详解
R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...
QMC5883L的驱动
简介 本篇文章的代码已经上传到了github上面,开源代码 作为一个电子罗盘模块,我们可以通过I2C从中获取偏航角yaw,相对于六轴陀螺仪的yaw,qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...

蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练
前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1):从基础到实战的深度解析-CSDN博客,但实际面试中,企业更关注候选人对复杂场景的应对能力(如多设备并发扫描、低功耗与高发现率的平衡)和前沿技术的…...

Cinnamon修改面板小工具图标
Cinnamon开始菜单-CSDN博客 设置模块都是做好的,比GNOME简单得多! 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...
Typeerror: cannot read properties of undefined (reading ‘XXX‘)
最近需要在离线机器上运行软件,所以得把软件用docker打包起来,大部分功能都没问题,出了一个奇怪的事情。同样的代码,在本机上用vscode可以运行起来,但是打包之后在docker里出现了问题。使用的是dialog组件,…...

ABAP设计模式之---“简单设计原则(Simple Design)”
“Simple Design”(简单设计)是软件开发中的一个重要理念,倡导以最简单的方式实现软件功能,以确保代码清晰易懂、易维护,并在项目需求变化时能够快速适应。 其核心目标是避免复杂和过度设计,遵循“让事情保…...

Reasoning over Uncertain Text by Generative Large Language Models
https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...