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

MySQL 与 PostgreSQL 关键对比二(SQL语法)

目录

1 详细示例

1.1自动增量列

1.2 字符串连接

1.3 JSON 支持

2 总结


MySQL 和 PostgreSQL 是两种流行的开源关系数据库管理系统(RDBMS)。尽管它们在许多方面相似,但在 SQL 语法和功能上存在一些显著差异。

以下SQL语句的执行如果需要开发工具支持,可以尝试使用SQLynx或Navicat来执行。

以下是 MySQL 和 PostgreSQL 在 SQL 方面的主要差异的对比表:

类别MySQLPostgreSQL
数值类型TINYINT, SMALLINT, MEDIUMINT, INT, BIGINTSMALLINT, INTEGER, BIGINT
日期和时间类型DATE, DATETIME, TIMESTAMP, TIME, YEARDATE, TIMESTAMP, TIMESTAMPTZ, TIME, TIMETZ, INTERVAL
字符串类型CHAR, VARCHAR, TEXT, BLOBCHAR, VARCHAR, TEXT, BYTEA
自动增量列AUTO_INCREMENTSERIAL, BIGSERIAL
字符串连接CONCAT()`
公共表表达式(CTE)从 8.0 版本开始支持长期支持
JSON 支持从 5.7 版本开始支持 JSON 类型和函数从 9.2 版本开始支持 JSON,从 9.4 版本开始支持 JSONB,提供丰富的操作函数和操作符
索引类型B-tree, Full-text, Hash(仅限 MEMORY 引擎)B-tree, Hash, GiST, SP-GiST, GIN, BRIN,多种索引类型,允许创建自定义索引
并发控制默认使用 InnoDB 引擎,支持行级锁和 MVCC原生支持 MVCC,高效的并发控制
存储过程和函数使用 DELIMITER 命令定义存储过程使用 CREATE FUNCTIONPL/pgSQL 定义存储过程
高可用性和集群支持主从复制、组复制和 InnoDB 集群支持物理和逻辑复制,提供 pgpool-IIPatroni 等工具实现高可用性和自动故障转移

1 详细示例

1.1自动增量列
  • MySQL:

    CREATE TABLE users (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(100)
    );
    

  • PostgreSQL:

    CREATE TABLE users (id SERIAL PRIMARY KEY,name VARCHAR(100)
    );
    

1.2 字符串连接
  • MySQL:

    SELECT CONCAT(first_name, ' ', last_name) AS full_name FROM users;
    

  • PostgreSQL:

    SELECT first_name || ' ' || last_name AS full_name FROM users;
    

1.3 JSON 支持
  • MySQL:

    CREATE TABLE users (id INT PRIMARY KEY,data JSON
    );SELECT JSON_EXTRACT(data, '$.name') FROM users;
    

  • PostgreSQL:

    CREATE TABLE users (id SERIAL PRIMARY KEY,data JSONB
    );SELECT data->>'name' FROM users;
    

2 总结

选择 MySQL 还是 PostgreSQL 取决于具体的需求和应用场景。MySQL 通常更适用于简单的 Web 应用和频繁读取的场景,而 PostgreSQL 则因其强大的功能和高扩展性更适用于复杂查询和大数据处理的场景。

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

相关文章:

  • 徐州服务器租用该如何维护?
  • C++习题精选(4)—— 栈
  • Web前端ES6-ES13笔记合集(下)
  • 我要成为算法高手-双指针篇
  • Fake news detection: A survey of graph neural network methods
  • HCIE认证,这些误区要避开
  • 主题切换之CSS文件篇
  • Vue进阶(八十八)前端测试工具介绍
  • 【录制,纯正人声】OBS录制软件,音频电流音,杂音解决办法,录制有噪声的解决办法
  • Django中drf动态过滤查询
  • GTSAM | gtsam::PriorFactor
  • MMSegmentation改进:增加Kappa系数评价指数
  • 专栏【汇总】
  • 成功解决IndexError: index 0 is out of bounds for axis 1 with size 0
  • C# MES通信从入门到精通(11)——C#如何使用Json字符串
  • ON DUPLICATE KEY UPDATE 子句
  • perl use HTTP::Server::Simple 轻量级 http server
  • 【STM32】基于I2C协议的OLED显示(利用U82G库)
  • 掌握Python3输入输出:轻松实现用户交互、日志记录与数据处理
  • 用于每个平台的最佳WordPress LMS主题
  • pytorch 加权CE_loss实现(语义分割中的类不平衡使用)
  • 【iOS】UI——关于UIAlertController类(警告对话框)
  • django支持https
  • 算法题day41(补5.27日卡:动态规划01)
  • 【附带源码】机械臂MoveIt2极简教程(四)、第一个入门demo
  • 基于蚁群算法的二维路径规划算法(matlab)
  • 政务云参考技术架构
  • android 13 aosp 预置so库
  • mongo篇---mongoDB Compass连接数据库
  • 基于SOA海鸥优化算法的三维曲面最高点搜索matlab仿真