PostgreSQL常用命令

PostgreSQL官网:https://www.postgresql.org

连接数据库

psql -h host -p port -U username -d database 
  • host:数据库主机名或 IP 地址。
  • port:数据库端口号(默认为 5432)。
  • username:连接数据库所使用的用户名。
  • database:数据库名称。

断开psql客户端

\q或按Ctrl+D组合键

清空屏幕

\! clear;

查看支持的所有命令

?

查看所有sql命令帮助

\h

查看某个具体的sql命令

\h sql命令

查看所有数据库

\l或\list

切换数据库

\c database

查看当前数据库所有表、视图、序列

\d

查看表定义

\d 表名

查看表大小

\dt+ 表名

查看索引

\di

查看索引大小

\di+ 索引名

查看表空间

\db

查看所有schema

\dn

查看所有角色或用户

\du或\dg

设置查询结果的输出模式(相当于mysql的\G)

\x

导出数据库

pg_dump 是 PostgreSQL 自带的备份工具,可以用于导出数据库和表的数据和结构。

pg_dump -h host -p port -U username -d database -f database.sql
  • host:数据库主机名或 IP 地址。
  • port:数据库端口号(默认为 5432)。
  • username:连接数据库所使用的用户名。
  • database:要导出的数据库名称。
  • database.sql:导出的 SQL 脚本文件。
    --inserts:将数据转储为INSERT命令,而不是COPY

如果只想导出数据库的结构而不包含数据,可以使用以下命令:

pg_dump -h host -p port -U username -d database -s -f database.sql

-s 参数表示只导出数据库的结构而不包括数据。

如果只想导出数据库的数据而不包含结构,可以使用以下命令:

pg_dump -h host -p port -U username -d database -a -f database.sql

-a 参数表示只导出数据而不导出表结构。

导出某张表

pg_dump -h host -p port -U username -d database -t table_name -f table_name.sql
  • host:数据库主机名或 IP 地址。
  • port:数据库端口号(默认为 5432)。
  • username:连接数据库所使用的用户名。
  • database:要导出的数据库名称。
  • table_name:要导出的表名。
  • table_name.sql:导出的 SQL 脚本文件。

如果只想导出表的数据而不导出表结构,可以使用以下命令:

pg_dump -h host -p port -U username -d database -t table_name -a -f table_name.sql

-a 参数表示只导出数据而不导出表结构。

如果只想导出表的结构而不导出表数据,可以使用以下命令:

pg_dump -h host -p port -U username -d database -t table_name -s -f table_name.sql

-s 参数表示只导出结构而不包括数据。

如果想同时导出多张表,用多个-t 表名即可。

pg_dump -h host -p port -U username -d database -t table_a_name -t table_b_name
-s -f table_name.sql

将两个经纬度字段(latitude和longitude)转换为Geometry并赋值给一个新的字段location:

UPDATE your_table SET location = ST_SetSRID(ST_MakePoint(longitude, latitude), 4326) WHERE condition;

其中,your_table表示要更新的表名,condition是指定需要更新记录的条件。这里使用了ST_MakePoint函数来创建点对象,参数分别是经度和纬度;然后通过ST_SetSRID函数设置空间参考系统标识符为4326(WGS84地理坐标系)。最后,将生成的Geometry对象赋值给location字段。传入的geometry参数的 SRID 必须是 4326 或 4490 ,否则返回null。

geom转换成经纬度

SELECT ST_AsText(geom) FROM table;

生成UUID

UUID(Universal Unique Identifier)或者 GUID(Globally Unique Identifier)是一个 128 比特的数字,可以用于唯一标识每个网络对象或资源。由于它的生成机制,一个 UUID 可以保证几乎不会与其他 UUID 重复,因此常常用于生成数据库中的主键值。

PostgreSQL 提供了一个用于加/解密的扩展模块 pgcrypto,其中的 gen_random_uuid() 函数可以用于返回一个 version 4 的随机 UUID。首先,输入以下命令启用该模块(gen_random_uuid() 从 PostgreSQL 13 开始成为了一个内置函数):

CREATE EXTENSION pgcrypto;

生成uuid:

SELECT gen_random_uuid();

该函数返回的数据类型为 uuid。如果想要生成没有中划线(-)的 UUID 字符串,可以使用 REPLACE 函数:

SELECT replace(gen_random_uuid()::text,'-','');

根据关联表更新另一张表数据

关联表形式:

UPDATE 待更新表 t1
SET 待更新表字段 = t2.字段,
待更新表字段 = t2.字段
FROM
    关联表 t2 
WHERE
    t1.关联字段 = t2.关联字段
 
--例:街镇表根据编号关联地区表,更新街镇名称
UPDATE town t1
SET town_name = t2."name"
FROM
    region t2 
WHERE
    t1.town_code = t2.code

子查询形式:

UPDATE 待更新表 t1
SET (待更新表字段, 待更新表字段) = 
(SELECT t2.字段, t2.字段 FROM 关联表 t2 WHERE t1.关联字段 = t2.关联字段)

注意点:
1.SET后的待更新字段不要加表别名(如t1),会识别成列名,报(column "表别名" of relation "待更新表名" does not exist)错误。
2.子查询形式字段要一一对应,顺序不能乱。

INSERT SELECT

INSERT INTO target_table (column1, column2, column3, ...)
SELECT column1, column2, column3, ...
FROM source_table
WHERE condition;

target_table是要插入数据的目标表,source_table是要从中选择数据的源表。您可以通过选择源表中的列,并将它们映射到目标表的对应列来指定要插入的数据,还可以添加WHERE子句来过滤源表中的数据。

将查询结果导出csv文件

copy (select * from test where create_time >= '2024-01-01') to '/tmp/data/test.csv' with csv header;

判断字符串是否是数字

PostgreSQL支持正则表达式,通过~操作符可以匹配字符串是否符合特定的模式,要检查一个字符串是否全由数字组成,可以使用^[0-9]+$这样的正则表达式:
^表示字符串的开始
[0-9] 表示任何一个数字字符
+表示前面的字符(这里是数字)出现一次或多次
$ 表示字符串的结束
示例:

SELECT column_name
FROM table_name
WHERE column_name ~ '^[0-9]+$';

逻辑删除设置唯一索引

假设users表设置未删除的username唯一,del_flag(0-未删除,1-已删除)

CREATE UNIQUE INDEX uk_users_username ON users (username) WHERE del_flag = 0;

参考:PG+PostGIS转换火星坐标系、百度等坐标系方法
PostgreSQL 教程

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容