PostgreSQL CRUD 操作指南
PostgreSQL CRUD 操作指南
连接数据库
-- 连接到特定数据库
psql -U postgres -d xianxia-- 列出所有数据库
\l-- 切换数据库
\c xianxia-- 列出所有表
\dt-- 查看表结构
\d table_name
基本 CRUD 操作
CREATE(创建)
-- 创建新表
CREATE TABLE users (id SERIAL PRIMARY KEY,username VARCHAR(50) UNIQUE NOT NULL,email VARCHAR(100) UNIQUE NOT NULL,created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);-- 插入单条数据
INSERT INTO users (username, email)
VALUES ('admin', 'admin@example.com');-- 插入多条数据
INSERT INTO users (username, email)
VALUES ('user1', 'user1@example.com'),('user2', 'user2@example.com');
READ(查询)
-- 查询所有列
SELECT * FROM users;-- 查询特定列
SELECT username, email FROM users;-- 条件查询
SELECT * FROM users WHERE username = 'admin';-- 排序
SELECT * FROM users ORDER BY created_at DESC;-- 分页查询
SELECT * FROM users
LIMIT 10 OFFSET 0; -- 第一页,每页10条-- 模糊查询
SELECT * FROM users
WHERE username LIKE '%admin%';-- 联表查询
SELECT u.username, p.title
FROM users u
JOIN posts p ON u.id = p.user_id;
UPDATE(更新)
-- 更新单个字段
UPDATE users
SET email = 'newemail@example.com'
WHERE username = 'admin';-- 更新多个字段
UPDATE users
SET email = 'newemail@example.com',username = 'newadmin'
WHERE id = 1;-- 批量更新
UPDATE users
SET status = 'inactive'
WHERE last_login < NOW() - INTERVAL '30 days';
DELETE(删除)
-- 删除特定记录
DELETE FROM users
WHERE username = 'admin';-- 删除所有记录
DELETE FROM users;-- 截断表(更快的清空表方式)
TRUNCATE TABLE users;-- 删除表
DROP TABLE users;
高级操作
事务处理
-- 开始事务
BEGIN;-- 执行操作
INSERT INTO users (username, email) VALUES ('user1', 'user1@example.com');
UPDATE accounts SET balance = balance - 100 WHERE user_id = 1;-- 提交事务
COMMIT;-- 回滚事务
ROLLBACK;
索引操作
-- 创建索引
CREATE INDEX idx_username ON users(username);-- 创建唯一索引
CREATE UNIQUE INDEX idx_email ON users(email);-- 删除索引
DROP INDEX idx_username;
常用函数
-- 计数
SELECT COUNT(*) FROM users;-- 分组统计
SELECT status, COUNT(*)
FROM users
GROUP BY status;-- 聚合函数
SELECT AVG(age) as average_age,MAX(age) as max_age,MIN(age) as min_age
FROM users;
实用技巧
备份和恢复
# 备份数据库
pg_dump -U postgres xianxia > backup.sql# 恢复数据库
psql -U postgres xianxia < backup.sql
性能优化
- 使用 EXPLAIN 分析查询
EXPLAIN ANALYZE
SELECT * FROM users WHERE email = 'admin@example.com';
- 创建合适的索引
-- 为经常查询的字段创建索引
CREATE INDEX idx_email ON users(email);
- 定期维护
-- 清理和分析数据库
VACUUM ANALYZE users;
常见问题解决
- 连接问题
-- 查看当前连接
SELECT * FROM pg_stat_activity;-- 终止特定连接
SELECT pg_terminate_backend(pid);
- 权限问题
-- 授予权限
GRANT ALL PRIVILEGES ON DATABASE xianxia TO username;-- 撤销权限
REVOKE ALL PRIVILEGES ON DATABASE xianxia FROM username;
最佳实践
- 总是使用事务来保证数据一致性
- 为频繁查询的字段创建索引
- 定期进行数据库维护和备份
- 使用参数化查询防止SQL注入
- 适当使用视图简化复杂查询
- 遵循命名规范
- 为表添加适当的约束
相关文章:
PostgreSQL CRUD 操作指南
PostgreSQL CRUD 操作指南 连接数据库 -- 连接到特定数据库 psql -U postgres -d xianxia-- 列出所有数据库 \l-- 切换数据库 \c xianxia-- 列出所有表 \dt-- 查看表结构 \d table_name基本 CRUD 操作 CREATE(创建) -- 创建新表 CREATE TABLE users …...
4X4规模S盒分量布尔函数计算工具(附各大常见分组加密算法S盒查找表和其对应分量布尔函数截图)
文章结尾有S盒分量布尔函数计算工具下载地址 Serpent {0x3,0x8,0xF,0x1,0xA,0x6,0x5,0xB,0xE,0xD,0x4,0x2,0x7,0x0,0x9,0xC} LBlock {0xE,0x9,0xF,0x0,0xD,0x4,0xA,0xB,0x1,0x2,0x8,0x3,0x7,0x6,0xC,0x5} GOST {0x4,0xA,0x9,0x2,0xD,0x8,0x0,0xE,0x6,0xB,0x1,0xC,0x7,0xF,0x5,0…...
模拟——郑益慧_笔记1_绪论
B站视频链接 模电是数电的基础;参考书: 模拟电子技术基础(第四版)华成英、童诗白主编,高等教育出版社;电子技术基础 模拟部分 康华光主编,高等教育出版社; 电子技术的发展史 电子…...
金融租赁系统的发展与全球化战略实施探讨
内容概要 金融租赁系统的演变并非一帆风顺,像一场跌宕起伏的电影。首先,咱们得看看它的起源及现状。随着经济的快速发展,金融租赁逐渐作为一种灵活的融资手段崭露头角。在中国市场中,企业对设备和技术更新换代的需求日益迫切&…...
vue3入门教程:计算属性
计算属性的基本用法 计算属性是通过computed函数创建的,它接受一个getter函数作为参数,并返回一个只读的响应式ref对象。该ref对象通过.value属性暴露getter函数的返回值。 <template><div><p>原始数据: {{ count }}</p><p…...
Docker怎么关闭容器开机自启,批量好几个容器一起操作?
环境: WSL2 docker v25 问题描述: Docker怎么关闭容器开机自启,批量好几个容器一起操作? 解决方案: 在 Docker 中,您可以使用多种方法来关闭容器并配置它们是否在系统启动时自动启动。以下是具体步骤和…...
shell脚本(全)
shell脚本概述 第一个shell脚本 shell注释 shell变量 shell位置参数 shell字符串 shell内置命令 shell命令替换 输出 流程控制IF export命令 退出脚本 运行Shell脚本 实例导航 shell脚本概述 在说什么是shell脚本之前,先说说什么是shell。 从程序员的…...
华为手机建议使用adb卸载的app
按需求自行卸载 echo 卸载智慧搜索 adb shell pm uninstall -k --user 0 com.huawei.search echo 卸载智慧助手 adb shell pm uninstall -k --user 0 com.huawei.intelligent echo 卸载讯飞语音引擎 adb shell pm uninstall -k --user 0 com.iflytek.speechsuite echo 卸载快应…...
论文解读 | EMNLP2024 一种用于大语言模型版本更新的学习率路径切换训练范式
点击蓝字 关注我们 AI TIME欢迎每一位AI爱好者的加入! 点击 阅读原文 观看作者讲解回放! 作者简介 王志豪,厦门大学博士生 刘诗雨,厦门大学硕士生 内容简介 新数据的不断涌现使版本更新成为大型语言模型(LLMsÿ…...
Java基础(Json和Java对象)
定义好实体类 package com.pyb.pojo; /*** version 1.0* Author 彭彦彬* Date 2024/12/24 20:47* 注释*/ public class Person {private String username;private String password; public Person() {} public Person(String username, String password) {this.username…...
Linux 中检查 Apache Web Server (httpd) 正常运行时间的 4 种方法
注:机翻,未校。 4 Ways To Check Uptime of Apache Web Server (httpd) on Linux November 28, 2019 by Magesh Maruthamuthu We all know about the purpose of uptime command in Linux. 我们都知道 Linux 中 uptime 命令的目的。 It is used to c…...
Linux驱动开发--字符设备驱动开发
一、概述 字符设备是 Linux 驱动中最基本的一类设备驱动,字符设备就是一个一个字节,按照字节 流进行读写操作的设备,读写数据是分先后顺序的。比如我们最常见的点灯、按键、 IIC、 SPI, LCD 等等都是字符设备,这些设备的驱动就叫做字符设备驱动。 Linux 应用程序对驱动程…...
MarkItDown的使用(将Word、Excel、PDF等转换为Markdown格式)
MarkItDown的使用(将Word、Excel、PDF等转换为Markdown格式) 本文目录: 零、时光宝盒🌻 一、简介 二、安装 三、使用方法 3.1、使用命令行形式 3.2、用 Python 调用 四、总结 五、参考资料 零、时光宝盒🌻 &a…...
一文彻底拿捏DevEco Studio的使用小技巧
程序员Feri一名12年的程序员,做过开发带过团队创过业,擅长Java相关开发、鸿蒙开发、人工智能等,专注于程序员搞钱那点儿事,希望在搞钱的路上有你相伴!君志所向,一往无前! 0.安装DevEco Studio DevEco Studio面向HarmonyOS应用及元服务开发者提供的集成开…...
R9000P键盘失灵解决办法
问题描述 突然,就是很突然,我买的R9000P 2024不到三个月,键盘突然都不能用了,是所有键盘按键都无效的那种。(可以使用外接键盘) 解决办法 我本科室友说的好哈,全坏全没坏。 (该解…...
【Linux之Shell脚本实战】编写简单计算器shell脚本
【Linux之Shell脚本实战】编写简单计算器shell脚本 一、Shell脚本介绍1.1 Shell脚本简介1.2 Shell脚本特点二、脚本要求三、检查本地环境3.1 本地环境规划3.2 检查本地系统3.3 检查系统内核版本四、编写脚本4.1 脚本内容4.2 脚本分析整体逻辑各功能实现使用方法4.3 执行效果五、…...
【0x001D】HCI_Read_Remote_Version_Information命令详解
目录 一、命令概述 二、命令格式及参数说明 2.12. HCI_Read_Remote_Version_Information 命令格式 2.2. Connection_Handle 三、生成事件 3.1. HCI_Command_Status 事件 3.2. HCI_Read_Remote_Version_Information_Complete 事件 四、命令执行流程 4.1. 命令发起阶段(…...
秒鲨后端之MyBatis【2】默认的类型别名、MyBatis的增删改查、idea中设置文件的配置模板、MyBatis获取参数值的两种方式、特殊SQL的执行
别忘了请点个赞收藏关注支持一下博主喵!!!! ! ! 下篇更新: 秒鲨后端之MyBatis【3】自定义映射resultMap、动态SQL、MyBatis的缓存、MyBatis的逆向工程、分页插件。 默认的类型别名 MyBatis的增删改查 添加 <!--int insertUs…...
python中使用selenium执行组合快捷键ctrl+v不生效问题
在执行ctrlv进行粘贴时,绑定一个页面上的元素对象(无论元素对象是否是引用过期或者是粘贴的目标文本区,但前提需要粘贴的目标文本区获取焦点)执行ctrlv后可以生效。执行粘贴组合快捷键(ctrlv)的示例代码 se…...
大语言模型中的Agent;常见的Agent开发工具或框架
大语言模型中的Agent 大语言模型中的Agent是指以大语言模型为核心驱动,具有自主理解、感知、规划、记忆和使用工具等能力,能够自动化执行复杂任务的系统.以下是一些例子: AutoGPT:它相当于一个完整的工具包,可以为各种项目构建和运行自定义AI Agent。使用OpenAI的GPT-4和…...
基于DSP28335逆变器程序,单相全桥逆变器程序,采用双极性调制 程序逻辑清晰,注释详细,详...
基于DSP28335逆变器程序,单相全桥逆变器程序,采用双极性调制 程序逻辑清晰,注释详细,详细到几乎每一句都有注释,对于小白异常友好,有些地方甚至基本原理都补充写明了,百分之99的程序注释不会有我…...
Cortex-A7 vs Cortex-A9 vs Cortex-A53:ARM架构演进与移动处理器选型指南
1. ARM架构演进简史:从A7到A53的技术跃迁 2005年首次亮相的Cortex-A8揭开了智能手机处理器的序幕,而真正让移动计算进入多核时代的则是2007年问世的Cortex-A9。这个采用乱序执行架构的处理器让安卓设备首次突破1GHz主频,德州仪器的OMAP4430和…...
自动化测试框架选型:为什么我们最终选择了Playwright?
在软件质量保障体系中,UI自动化测试框架的选型是一个至关重要的技术决策。面对市场上众多的选择,如老牌的Selenium、现代的Cypress以及后起之秀Playwright,如何做出既符合当下技术趋势,又能满足团队长期发展需求的选择,…...
Exegol未来展望:AI驱动的安全测试与云原生架构的发展趋势
Exegol未来展望:AI驱动的安全测试与云原生架构的发展趋势 【免费下载链接】Exegol Fully featured and community-driven hacking environment 项目地址: https://gitcode.com/gh_mirrors/ex/Exegol Exegol作为一个功能全面且社区驱动的网络安全测试环境&…...
【arcgis进阶】高效实现线要素转面要素并保持属性同步的3种方法
1. 为什么需要线要素转面要素? 在GIS数据处理中,线要素和面要素是两种最基本的几何类型。线要素通常用于表示道路、河流等线性特征,而面要素则用于表示地块、湖泊等封闭区域。但在实际项目中,我们经常需要将线要素转换为面要素&am…...
零成本解锁游戏串流新姿势:Sunshine自托管服务器全攻略
零成本解锁游戏串流新姿势:Sunshine自托管服务器全攻略 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine 价值定位:打破游戏设备边界的开源方案 痛点-方案-收…...
C++ 拷贝构造函数深度解析:从浅拷贝到深拷贝
引言在 C 面向对象编程中,拷贝构造函数是一个既基础又容易出错的话题。很多初学者(包括曾经的我)在遇到指针成员时,常常因为默认的浅拷贝而导致程序崩溃或内存错误。我想通过自己的学习笔记和实践经验,系统地分享拷贝构…...
Cursor AI 试用限制的技术突破与自动化解决方案
Cursor AI 试用限制的技术突破与自动化解决方案 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your trial request limit.…...
终极PT资源管理工具:auto_feed_js实现100+站点一键转载的高效解决方案
终极PT资源管理工具:auto_feed_js实现100站点一键转载的高效解决方案 【免费下载链接】auto_feed_js PT站一键转载脚本 项目地址: https://gitcode.com/gh_mirrors/au/auto_feed_js 在PT资源分享的世界里,每一位爱好者都曾面临过重复填写资源信息…...
破局资源获取困境:猫抓浏览器扩展全攻略
破局资源获取困境:猫抓浏览器扩展全攻略 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 在数字化时代,网络媒体资源已成为我…...
