news 2026/6/20 21:58:51

PostgreSQL vs MySQL:从零开始基础命令对比指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
PostgreSQL vs MySQL:从零开始基础命令对比指南

背景

据说 如果你熟悉 MySQL,切换到 PostgreSQL 就像从 Windows 切换到 macOS:都是电脑,比较简单,
但是 但操作习惯不同。
老是不习惯 写篇文章对比一下吧 给其他小伙伴

基础连接对比

MySQL

# 连接数据库mysql -u root -p# 进入后mysql>SHOW DATABASES;mysql>USE database_name;mysql>SHOW TABLES;

PostgreSQL

# 连接数据库psql -U postgres -d database_name# 进入后postgres=# \l -- 相当于 SHOW DATABASESpostgres=# \c database_name -- 相当于 USE database_namepostgres=# \dt -- 相当于 SHOW TABLES

常用操作对照表

操作MySQLPostgreSQL解释
查看所有数据库SHOW DATABASES;\lPostgreSQL 用反斜杠命令
使用数据库USE dbname;\c dbname切换当前数据库
查看所有表SHOW TABLES;\dt注意:是\dt不是/dt
查看表结构DESC table_name;\d table_namePostgreSQL 的\d更强大
查看表详情SHOW CREATE TABLE table_name;\d+ table_name显示索引、约束等
退出客户端exit;quit;\q简单一个字母
执行SQL文件source file.sql;\i file.sql导入外部SQL
查看帮助help;\?元命令帮助

SQL语法关键差异

1. 限制查询结果

-- MySQLSELECT*FROMuserLIMIT10;-- PostgreSQLSELECT*FROM"user"LIMIT10;-- 或更标准的SELECT*FROM"user"FETCHFIRST10ROWSONLY;

2. 自增ID

-- MySQLCREATETABLEuser(idINTAUTO_INCREMENTPRIMARYKEY);-- PostgreSQLCREATETABLE"user"(idSERIALPRIMARYKEY);-- 或(现代方式)CREATETABLE"user"(idINTGENERATED ALWAYSASIDENTITYPRIMARYKEY);

3. 字符串连接

-- MySQLSELECTCONCAT(name,' (',phone,')')FROMuser;-- PostgreSQLSELECTname||' ('||phone||')'FROM"user";-- 或SELECTCONCAT(name,' (',phone,')')FROM"user";

4. 当前时间

-- MySQLSELECTNOW();-- 2025-01-15 10:30:00SELECTCURDATE();-- 2025-01-15-- PostgreSQLSELECTNOW();-- 2025-01-15 10:30:00.123456+08SELECTCURRENT_DATE;-- 2025-01-15 (注意:没有括号)

实战示例:用户表操作

创建用户表

-- MySQLCREATETABLEuser(idVARCHAR(20)PRIMARYKEY,phoneVARCHAR(15)UNIQUENOTNULL,passwordVARCHAR(128),nameVARCHAR(50),ageINT,created_atBIGINTDEFAULTUNIX_TIMESTAMP(),updated_atBIGINTDEFAULTUNIX_TIMESTAMP()ONUPDATEUNIX_TIMESTAMP());-- PostgreSQLCREATETABLE"user"(idVARCHAR(20)PRIMARYKEY,phoneVARCHAR(15)UNIQUENOTNULL,passwordVARCHAR(128),nameVARCHAR(50),ageINT,created_atBIGINTDEFAULTEXTRACT(EPOCHFROMNOW()),updated_atBIGINTDEFAULTEXTRACT(EPOCHFROMNOW()));-- PostgreSQL 需要创建触发器来更新 updated_atCREATEORREPLACEFUNCTIONupdate_updated_at_column()RETURNSTRIGGERAS$$BEGINNEW.updated_at=EXTRACT(EPOCHFROMNOW());RETURNNEW;END;$$language'plpgsql';CREATETRIGGERupdate_user_updated_at BEFOREUPDATEON"user"FOR EACH ROWEXECUTEFUNCTIONupdate_updated_at_column();

查询用户数据

-- 两者通用(PostgreSQL 表名需要引号)SELECT*FROM"user"WHEREphone='13634759152';-- 时间戳转换(PostgreSQL 更强大)-- MySQLSELECTFROM_UNIXTIME(created_at)FROMuser;-- PostgreSQLSELECTTO_TIMESTAMP(created_at)FROM"user";SELECTcreated_at*INTERVAL'1 second'FROM"user";

为什么会有这些差异?

  1. 历史原因:两个数据库独立发展30+年
  2. 标准遵循:PostgreSQL 更遵循 SQL 标准
  3. 设计理念
    • MySQL:简单快速,“够用就好”
    • PostgreSQL:功能完备,“严格标准”

迁移时需要改什么?

代码层面

  1. 连接字符串

    # MySQL"mysql+pymysql://user:pass@localhost/db"# PostgreSQL"postgresql+psycopg2://user:pass@localhost/db"
  2. ORM配置

    # SQLAlchemy 中# MySQL 可以用 AUTO_INCREMENT# PostgreSQL 用 SERIAL 或 IDENTITY

运维层面

  1. 备份恢复

    # MySQLmysqldump -u root db>backup.sql mysql -u root db<backup.sql# PostgreSQLpg_dump -U postgres db>backup.sql psql -U postgres db<backup.sql
  2. 权限管理:PostgreSQL 更细粒度,也更复杂 但是主流推荐

你应该选择哪个?

选 MySQL 如果:

  • 需要简单快速上手
  • 项目主要是读操作
  • 团队熟悉 MySQL 生态
  • 使用 WordPress、Laravel 等框架

选 PostgreSQL 如果:

  • 需要复杂查询和事务
  • 数据一致性要求高
  • 需要 JSON、GIS、全文搜索等高级功能
  • 项目会长期发展,需要扩展性

常见坑点提醒

  1. 表名大小写:PostgreSQL 默认小写,如果创建了"User",查询必须用引号
  2. 反斜杠 vs 正斜杠\dt✓,/dt
  3. 命令结束符:两者都用;,但 PostgreSQL 的元命令不用
  4. 时间处理:PostgreSQL 时区处理更严格

一句话建议

把 PostgreSQL 当成一个全新的数据库来学,不要尝试把 MySQL 的习惯带过去。掌握\开头的元命令,理解严格的大小写和类型系统,你会发现 PostgreSQL 的强大之处。


据说:如果你用 Docker,两者的差异会更明显。PostgreSQL 的数据卷需要正确配置权限,而 MySQL 通常 “just works”。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/13 22:38:19

基于微信小程序的校园电子请假系统毕设

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在设计并实现一款基于微信小程序的校园电子请假系统&#xff0c;以提升校园管理效率&#xff0c;优化学生请假流程。具体研究目的如下&#xff1a;提高校…

作者头像 李华
网站建设 2026/6/13 21:58:33

国家专精特新小巨人补贴,申报条件

一、国家专精特新小巨人补贴1、资金扶持&#xff1a;每户给予一次性100万奖补&#xff08;以各地方具体奖补金额为准&#xff09;。2、荣誉资质&#xff1a;颁发“国家专精特新小巨人”企业证书。3、政策帮助&#xff1a;重点对企业发展中遇到的困难&#xff0c;是“一企一策”…

作者头像 李华
网站建设 2026/6/19 2:34:56

GraniStudio零代码平台主任务设计器如何快速定位算子?

GraniStudio平台快速定位算子分两方面&#xff0c;一方面使用算子库查找&#xff0c;另一方面通过功能窗口查找。 算子库查找是编程时需要使用某个功能时通过输入算子名称查找相应算子或者控件&#xff0c;方便编程使用&#xff0c;在平台资源管理器、主任务设计器、HMI界面都支…

作者头像 李华
网站建设 2026/6/20 14:49:59

学网络安全需要会编程吗?

如今数据泄露、网络攻击频发&#xff0c;企业对安全人才的需求只增不减&#xff0c;不仅就业机会多&#xff0c;职业生命周期也更长&#xff0c;越有经验越吃香&#xff0c;完全不用担心35岁危机。那么学网络安全需要会编程吗?具体请看下文。学网络安全需要会编程吗?学网络安…

作者头像 李华
网站建设 2026/6/20 15:02:46

B站UP主招募:制作LobeChat测评视频享补贴

LobeChat&#xff1a;当开源遇上大模型&#xff0c;如何打造属于你的AI对话门户&#xff1f; 在大语言模型几乎每周都在刷新性能记录的今天&#xff0c;一个有趣的现象逐渐浮现&#xff1a;我们手握越来越强大的“大脑”——GPT-4、Claude 3、Qwen、ChatGLM……但让这些大脑真正…

作者头像 李华
网站建设 2026/6/18 3:10:28

二维码QRCode的属性

TQRCode组件生成二维码的核心属性配置&#xff0c;TQRCode是 Delphi 中常用的二维码生成组件&#xff08;多为第三方 / QRCode 库封装&#xff09;&#xff0c;以下逐一解析每个属性的功能、取值规则和实际应用场景&#xff1a; 一、核心属性解析 属性名代码赋值功能详解取值…

作者头像 李华