PostgreSQL 语法

PostgreSQL 语法

PostgreSQL 是一种功能强大的开源关系数据库管理系统,它以其稳定性、支持性、安全性和高级功能而闻名。本文将详细介绍 PostgreSQL 的基本语法,包括数据库和表的操作、查询语句、索引、触发器等。

数据库操作

创建数据库

sql 复制代码
CREATE DATABASE database_name;

删除数据库

sql 复制代码
DROP DATABASE database_name;

选择数据库

sql 复制代码
\c database_name;

表操作

创建表

sql 复制代码
CREATE TABLE table_name (
    column1 datatype,
    column2 datatype,
    column3 datatype,
    ...
);

删除表

sql 复制代码
DROP TABLE table_name;

修改表

添加列
sql 复制代码
ALTER TABLE table_name
ADD column_name datatype;
删除列
sql 复制代码
ALTER TABLE table_name
DROP COLUMN column_name;
修改列数据类型
sql 复制代码
ALTER TABLE table_name
ALTER COLUMN column_name SET DATA TYPE new_datatype;

数据操作

插入数据

sql 复制代码
INSERT INTO table_name (column1, column2, column3, ...)
VALUES (value1, value2, value3, ...);

更新数据

sql 复制代码
UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

删除数据

sql 复制代码
DELETE FROM table_name
WHERE condition;

查询语句

选择数据

sql 复制代码
SELECT column1, column2, ...
FROM table_name
WHERE condition;

排序数据

sql 复制代码
SELECT column1, column2, ...
FROM table_name
ORDER BY column1, column2, ... ASC|DESC;

聚合函数

sql 复制代码
SELECT COUNT(column_name)
FROM table_name
WHERE condition;

连接查询

内连接
sql 复制代码
SELECT columns
FROM table1
INNER JOIN table2
ON table1.column = table2.column;
左连接
sql 复制代码
SELECT columns
FROM table1
LEFT JOIN table2
ON table1.column = table2.column;
右连接
sql 复制代码
SELECT columns
FROM table1
RIGHT JOIN table2
ON table1.column = table2.column;

索引

创建索引

sql 复制代码
CREATE INDEX index_name
ON table_name (column1, column2, ...);

删除索引

sql 复制代码
DROP INDEX index_name;

触发器

创建触发器

sql 复制代码
CREATE TRIGGER trigger_name
BEFORE|AFTER INSERT|UPDATE|DELETE ON table_name
FOR EACH ROW
EXECUTE FUNCTION function_name();

删除触发器

sql 复制代码
DROP TRIGGER trigger_name ON table_name;

结语

PostgreSQL 的语法非常丰富,本文仅介绍了其基础部分。要成为一名熟练的 PostgreSQL 用户,还需要不断学习和实践。希望本文能为您在 PostgreSQL 的学习之旅中提供帮助。

相关推荐
PPPPPaPeR.1 分钟前
光学算法实战:深度解析镜片厚度对前后表面折射/反射的影响(纯Python实现)
开发语言·python·数码相机·算法
橙露4 分钟前
Java并发编程进阶:线程池原理、参数配置与死锁避免实战
java·开发语言
froginwe114 分钟前
C 标准库 - `<float.h>`
开发语言
2501_9160088915 分钟前
深入解析iOS机审4.3原理与混淆实战方法
android·java·开发语言·ios·小程序·uni-app·iphone
Dimpels35 分钟前
CANN ops-nn 算子解读:AIGC 批量生成中的 Batch 处理与并行算子
开发语言·aigc·batch
blueSatchel1 小时前
U-Boot载入到DDR过程的代码分析
linux·开发语言·u-boot
无小道1 小时前
QT——QFIie和QFileInfo文件类
开发语言·qt·命令模式
踢足球09291 小时前
寒假打卡:2026-2-7
java·开发语言·javascript
薛定谔的猫喵喵2 小时前
基于PyQt5的视频答题竞赛系统设计与实现
开发语言·qt·音视频
岱宗夫up2 小时前
Python 数据分析入门
开发语言·python·数据分析