当前位置: 首页 > news >正文

PostgreSQL 基本SQL语法(二)

1. SELECT 语句

1.1 基本 SELECT 语法

SELECT 语句用于从数据库中检索数据。基本语法如下:

SELECT column1, column2, ... FROM table_name;

例如,从 users 表中检索所有列的数据:

SELECT * FROM users;

1.2 使用 WHERE 条件

WHERE 子句用于过滤数据,仅返回满足条件的记录。基本语法如下:

SELECT column1, column2, ... FROM table_name WHERE condition;

例如,查询用户名为 alice 的用户:

SELECT * FROM users WHERE username = 'alice';

1.3 排序与限制(ORDER BY, LIMIT)

  • ORDER BY 子句用于对查询结果进行排序。
  • LIMIT 子句用于限制返回的记录数。

基本语法如下:

SELECT column1, column2, ... FROM table_name ORDER BY column1 [ASC|DESC] LIMIT number;

例如,按创建时间排序并返回前 5 条记录:

SELECT * FROM users ORDER BY created_at DESC LIMIT 5;

2. INSERT 语句

2.1 基本 INSERT 语法

INSERT 语句用于向表中插入数据。基本语法如下:

INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...);

例如,向 users 表中插入一条新记录:

INSERT INTO users (username, email) VALUES ('bob', 'bob@example.com');

2.2 插入多条记录

可以一次插入多条记录:

INSERT INTO users (username, email) VALUES ('charlie', 'charlie@example.com'), ('dave', 'dave@example.com');

2.3 插入数据的注意事项

  • 插入的数据类型必须与列的数据类型匹配。
  • 插入记录时,如果某列没有提供值且该列定义了默认值,则使用默认值。

3. UPDATE 语句

3.1 基本 UPDATE 语法

UPDATE 语句用于更新表中的数据。基本语法如下:

UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE condition;

例如,更新 bob 的电子邮件地址:

UPDATE users SET email = 'bob@newdomain.com' WHERE username = 'bob';

3.2 更新多个列

可以同时更新多个列:

UPDATE users SET email = 'dave@newdomain.com', username = 'dave_new' WHERE username = 'dave';

3.3 使用 RETURNING 返回更新后的数据

RETURNING 子句用于返回更新后的数据:

UPDATE users SET email = 'bob@anotherdomain.com' WHERE username = 'bob' RETURNING *;

4. DELETE 语句

4.1 基本 DELETE 语法

DELETE 语句用于从表中删除数据。基本语法如下:

DELETE FROM table_name WHERE condition;

例如,删除用户名为 charlie 的用户:

DELETE FROM users WHERE username = 'charlie';

4.2 使用 RETURNING 返回删除的数据

RETURNING 子句用于返回删除的数据:

DELETE FROM users WHERE username = 'charlie' RETURNING *;

5. 实战演练

5.1 练习题目

  1. 创建一个新表 products,包括以下列:

    • id(整数,主键,自增)
    • name(字符串,最大长度 100,不为空)
    • price(浮点数,不为空)
    • created_at(时间戳,默认为当前时间)
  2. products 表中插入以下数据:

    • nameLaptopprice 为 1200.00
    • nameSmartphoneprice 为 800.00
  3. 查询 products 表中所有价格大于 1000 的产品。

  4. Laptop 的价格更新为 1000.00,并返回更新后的记录。

  5. 删除 Smartphone 产品,并返回删除的记录。

5.2 示例答案

  1. 创建表:
CREATE TABLE products (id SERIAL PRIMARY KEY,name VARCHAR(100) NOT NULL,price NUMERIC NOT NULL,created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
  1. 插入数据:
INSERT INTO products (name, price)
VALUES ('Laptop', 1200.00),('Smartphone', 800.00);
  1. 查询价格大于 1000 的产品:
SELECT * FROM products WHERE price > 1000;
  1. 更新 Laptop 的价格并返回更新后的记录:
UPDATE products SET price = 1000.00 WHERE name = 'Laptop' RETURNING *;
  1. 删除 Smartphone 产品并返回删除的记录:
DELETE FROM products WHERE name = 'Smartphone' RETURNING *;


系统文章目录:

PostgreSQL 简介与基础(一)

PostgreSQL 基本SQL语法(二)

PostgreSQL 高级SQL查询(三)

PostgreSQL 数据库设计与管理(四)

PostgreSQL 高级功能(五)

PostgreSQL 性能优化与调优(六)

PostgreSQL 高可用性与灾难恢复策略(七)

PostgreSQL 安全性与权限管理(八)

PostgreSQL 高级功能与扩展(九)

PostgreSQL 分区表与并行查询(十)

PostgreSQL 索引优化与性能调优(十一)

PostgreSQL 日志管理与故障排查(十二)

PostgreSQL 高可用性与容错性(十三)

http://www.lryc.cn/news/389013.html

相关文章:

  • linux 控制台非常好用的 PS1 设置
  • 【紫光同创盘古PGX-Nano教程】——(盘古PGX-Nano开发板/PG2L50H_MBG324第十二章)Wifi透传实验例程说明
  • 详述乙级资质企业在城市综合管廊与隧道一体化设计中的挑战与机遇
  • 如何借助物联网实现农情监测与预警
  • 一个项目学习Vue3---响应式基础
  • 白骑士的Python教学基础篇 1.5 数据结构
  • Go 常用文件操作
  • 大数据、人工智能、云计算、物联网、区块链序言【大数据导论】
  • ComfyUI流程图、文生图、图生图步骤教学!
  • CSS基础知识学习指南
  • 力扣hot100 -- 贪心算法
  • P2P文件传输协议介绍
  • Spring Boot集成Spring Mobile快速入门Demo
  • 走进开源企业 | 湖南大学OpenHarmony技术实训活动在开鸿智谷顺利举办!
  • TCP单进程循环服务器程序与单进程客户端程序
  • QT+winodow 代码适配调试总结(二)
  • 百家讲坛 | 裴伟伟:企业中安全团队应当如何反馈漏洞
  • 巧用Fiddler中的Comments提升接口测试效率
  • 停车场车牌识别计费系统,用Python如何实现?
  • Linux内核——Linux内核体系模式(二)
  • Spring MVC的高级功能——异常处理(一)简单异常处理器
  • 【面试干货】Static关键字的用法详解
  • 软件工程实验
  • 对于复杂的网页布局,如多列布局和网格布局,CSS 有哪些最佳实践和技巧?
  • Spring Boot中集成Redis实现缓存功能
  • arco disign vue 日期组件的样式穿透
  • 【深度学习】pytorch训练中的一个大坑
  • python全局解释器锁(GIL)
  • 无人机的起源
  • 专题六:Spring源码之初始化容器BeanFactory