PostgreSQL掌握数据库与表操作,揭秘数据类型与运算符详解

PostgreSQL掌握数据库与表操作,揭秘数据类型与运算符详解


引言

PostgreSQL(简称 PG)是一款功能强大且开源的关系型数据库管理系统,以其稳定性、扩展性和丰富的数据类型著称。本文将带你从数据库的基本操作入手,深入剖析 PostgreSQL 中常见的数据类型与运算符,并通过代码示例图解帮助你快速掌握,轻松上手。


一、数据库操作

1. 创建与删除数据库

-- 创建数据库
CREATE DATABASE demo_db
    WITH
    OWNER = postgres           -- 指定拥有者
    ENCODING = 'UTF8'          -- 字符编码
    LC_COLLATE = 'en_US.utf8'  -- 排序规则
    LC_CTYPE = 'en_US.utf8'    -- 字符分类
    TEMPLATE = template0;      -- 基础模板

-- 删除数据库
DROP DATABASE IF EXISTS demo_db;

2. 查看与连接数据库

-- 查看所有数据库
\l

-- 连接到数据库
\c demo_db

-- 退出 psql 客户端
\q
图1:psql 客户端常用命令流程

┌────────────┐      ┌──────────┐      ┌─────────┐
│ 启动 psql  │ ──→ │ 查看数据库 │ ──→ │ 连接数据库 │
└────────────┘      └──────────┘      └─────────┘

二、表操作

1. 创建表

CREATE TABLE users (
    id SERIAL PRIMARY KEY,         -- 自增主键
    username VARCHAR(50) NOT NULL, -- 用户名
    email VARCHAR(100) UNIQUE,     -- 邮箱唯一
    created_at TIMESTAMP DEFAULT NOW()  -- 创建时间
);

2. 修改表结构

-- 添加列
ALTER TABLE users
ADD COLUMN bio TEXT;

-- 修改列类型
ALTER TABLE users
ALTER COLUMN username TYPE TEXT;

-- 重命名列
ALTER TABLE users
RENAME COLUMN bio TO biography;

3. 删除表

DROP TABLE IF EXISTS users;

4. 查看表结构

-- 查看表的列和约束
\d+ users
图2:表操作流程概览

[创建表] → [插入/查询/更新数据] → [修改表结构] → [删除表]

三、PostgreSQL 常见数据类型

类型类别数据类型用途描述
数值类型SMALLINT / INTEGER / BIGINT整数,分别对应 2、4、8 字节
DECIMAL(p,s) / NUMERIC定点数,精确到小数位
REAL / DOUBLE PRECISION浮点数,单精度/双精度
字符串类型CHAR(n) / VARCHAR(n) / TEXT固定/可变长度字符串
布尔类型BOOLEANTRUE / FALSE
日期时间类型DATE / TIME / TIMESTAMP日期、时间、日期+时间
枚举类型CREATE TYPE mood AS ENUM ('happy','sad');自定义枚举
JSON 类型JSON / JSONB存储 JSON 文档
UUIDUUID通用唯一标识符
数组类型integer[] / text[]任意维度的数组

图解:数据类型选型思路

┌─────────────┐
│ 是否需要精确 │ ── 是 → DECIMAL / NUMERIC
│(货币、财务)│
└─────────────┘
        ↓ 否
┌──────────────┐
│ 是否有枚举集 │ ── 是 → ENUM
└──────────────┘
        ↓ 否
┌─────────────────┐
│ 是否 JSON 结构?│ ── 是 → JSONB
└─────────────────┘
        ↓ 否
使用 INTEGER/TEXT 等通用类型

四、运算符详解

1. 算术运算符

SELECT 10 + 5 AS 加法, 
       10 - 5 AS 减法, 
       10 * 5 AS 乘法, 
       10 / 5 AS 除法, 
       10 % 3 AS 取余;
运算符含义
+加法
-减法
*乘法
/除法
%取余

2. 比较运算符

SELECT 5 = 5 AS 等于, 
       5 <> 3 AS 不等于, 
       5 > 3 AS 大于, 
       5 < 3 AS 小于, 
       5 >= 5 AS 大于等于, 
       5 <= 3 AS 小于等于;
运算符含义
=等于
<>不等于
>大于
<小于
>=大于等于
<=小于等于

3. 逻辑运算符

SELECT TRUE AND FALSE AS 逻辑与,
       TRUE OR FALSE  AS 逻辑或,
       NOT TRUE       AS 逻辑非;
运算符含义
AND逻辑与
OR逻辑或
NOT逻辑非

4. 文本运算符

SELECT 'Hello' || ' ' || 'World' AS 拼接;
运算符含义
\` \`字符串拼接

5. 数组与 JSON 运算符

-- 数组包含
SELECT ARRAY[1,2,3] @> ARRAY[2] AS 包含;

-- JSONB 存取
SELECT '{"a":1,"b":2}'::jsonb -> 'b' AS b键的值;
SELECT '{"a":1,"b":2}'::jsonb ->> 'b' AS b键的文本;
运算符用途
@>数组/JSON 包含关系
->JSONB 提取字段
->>JSONB 提取文本

五、综合示例

假设有一张订单表 orders,我们结合上述知识点做一次查询:

-- 表结构
CREATE TABLE orders (
    order_id SERIAL PRIMARY KEY,
    user_id INTEGER NOT NULL,
    items JSONB NOT NULL,              -- 存储订单商品列表
    total_amount NUMERIC(10,2) NOT NULL,-- 总金额
    created_at TIMESTAMP DEFAULT NOW()
);

-- 插入示例
INSERT INTO orders (user_id, items, total_amount)
VALUES
(1, '[{"name":"笔记本","price":4999.00},{"name":"鼠标","price":199.00}]', 5198.00),
(2, '[{"name":"键盘","price":299.00}]', 299.00);

-- 查询:筛选总金额大于1000并包含“笔记本”的订单
SELECT order_id, user_id, total_amount,
       items ->> 0 AS first_item
FROM orders
WHERE total_amount > 1000
  AND items @> '[{"name":"笔记本"}]';

解析:

  1. NUMERIC(10,2) 保证货币精度。
  2. items @> '[{"name":"笔记本"}]' 利用 JSONB 包含运算符筛选包含“笔记本”的订单。
  3. items ->> 0 提取 JSON 数组第一个元素并以文本形式输出。

结语

本文系统梳理了 PostgreSQL 数据库与表的基本操作,并详解了常见数据类型运算符,结合代码示例图解,帮助你迅速掌握核心概念。掌握之后,你就能灵活地设计表结构、选择合适的数据类型,并用丰富的运算符完成各类查询与数据处理。建议多动手实践,并结合官方文档深入钻研:

sql , db
最后修改于:2025年06月16日 12:21

评论已关闭

推荐阅读

AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日
python之plot()和subplot()画图
2024年11月26日
理解 DALL·E 2、Stable Diffusion 和 Midjourney 工作原理
2024年12月01日