`

PostgreSQL与MySQL区别

 
阅读更多
PostgreSQL 没有 MySQL 的各种坑MySQL 的各种 text 字段有不同的限制,
要手动区分 small text, middle text, large text... Pg 没有这个限制,
text 能支持各种大小.按照 SQL 标准, 做 null 判断不能用 = null, 只能用 is nullthe result of any arithmetic comparison with NULL is also NULL但 pg 可以设置 transform_null_equals 把 = null 翻译成 is null 避免踩坑不少人应该遇到过 MySQL 里需要 utf8mb4 才能显示 emoji 的坑, Pg 就没这个坑.MySQL 的事务隔离级别 repeatable read 并不能阻止常见的并发更新, 得加锁才可以, 但悲观锁会影响性能, 手动实现乐观锁又复杂. 而 Pg 的列里有隐藏的乐观锁 version 字段, 默认的 repeatable read 级别就能保证并发更新的正确性, 并且又有乐观锁的性能. 附带一个各数据库对隔离级别的行为差异比较调查: http://www.cs.umb.edu/~poneil/iso.pdfMySQL 不支持多个表从同一个序列中取 id, 而 Pg 可以.MySQL 不支持 OVER 子句, 而 Pg 支持. OVER 子句能简单的解决 "每组取 top 5" 的这类问题.几乎任何数据库的子查询 (subquery) 性能都比 MySQL 好.更多的坑:http://blog.ionelmc.ro/2014/12/28/terrible-choices-mysql/不少人踩完坑了, 以为换个数据库还得踩一次, 所以很抗拒, 事实上不是!!!Pg 不仅仅是 SQL 数据库它可以存储 array 和 json, 可以在 array 和 json 上建索引, 甚至还能用表达式索引. 为了实现文档数据库的功能, 设计了 jsonb 的存储结构. 有人会说为什么不用 Mongodb 的 BSON 呢? Pg 的开发团队曾经考虑过, 但是他们看到 BSON 把 ["a", "b", "c"] 存成 {0: "a", 1: "b", 2: "c"} 的时候就决定要重新做一个 jsonb 了... 现在 jsonb 的性能已经优于 BSON.现在往前端偏移的开发环境里, 用 Pg + PostgREST 直接生成后端 API 是非常快速高效的办法:begriffs/postgrest · GitHubpostgREST 的性能非常强悍, 一个原因就是 Pg 可以直接组织返回 json 的结果.它支持服务器端脚本: TCL, Python, R, Perl, Ruby, MRuby ... 自带 map-reduce 了.它有地理信息处理扩展 (GIS 扩展不仅限于真实世界, 游戏里的地形什么的也可以), 可以用 Pg 搭寻路服务器和地图服务器:PostGIS — Spatial and Geographic Objects for PostgreSQL它自带全文搜索功能 (不用费劲再装一个 elasticsearch 咯):Full text search in milliseconds with PostgreSQL 不过一些语言相关的支持还不太完善, 有个 bamboo 插件用调教过的 mecab 做中文分词, 如果要求比较高, 还是自己分了词再存到 tsvector 比较好.它支持 trigram 索引.trigram 索引可以帮助改进全文搜索的结果: PostgreSQL: Documentation: 9.3: pg_trgmtrigram 还可以实现高效的正则搜索 (原理参考 https://swtch.com/~rsc/regexp/regexp4.html )MySQL 处理树状回复的设计会很复杂, 而且需要写很多代码, 而 Pg 可以高效处理树结构:Scaling Threaded Comments on Django at Disqushttp://www.slideshare.net/quipo/trees-in-the-database-advanced-data-structures它可以高效处理图结构, 轻松实现 "朋友的朋友的朋友" 这种功能:http://www.slideshare.net/quipo/rdbms-in-the-social-networks-age它可以把 70 种外部数据源 (包括 Mysql, Oracle, CSV, hadoop ...) 当成自己数据库中的表来查询:Foreign data wrappers心动不如行动Converting MySQL to PostgreSQL
分享到:
评论

相关推荐

    PostgreSQL与MySQL比较

    "PostgreSQL与MySQL比较" PostgreSQL和MySQL是两种流行的开源关系数据库管理系统,它们之间有很多相似之处,但同时也存在一些关键的差异。本文将对PostgreSQL和MySQL进行详细的比较,涵盖它们的架构、性能、安全性...

    MySQL和PostgreSQL的比较

    ### MySQL与PostgreSQL对比分析 #### 一、实例与服务管理 **MySQL**与**PostgreSQL**在实例和服务管理方面存在显著差异。MySQL通过执行`mysqld`命令启动实例,一个实例能够管理一个或多个数据库,且一台服务器可...

    PostgreSQL与MySql比较

    ### PostgreSQL与MySQL比较 #### 一、MySQL与PostgreSQL对比概览 PostgreSQL与MySQL作为两种最流行的开源关系型数据库管理系统,在技术特性、应用场景及社区支持方面存在诸多不同。本篇将从多个角度深入探讨这两种...

    PostgreSQL和MySQL协议简介.pdf

    PostgreSQL和MySQL协议简介 一、网络协议概述 PostgreSQL和MySQL协议是数据库网络协议,属于OSI模型的应用层协议。网络协议是通信双方必须遵守的一组约定,包括语法、语义和时序三个要素。其中语法规定数据和控制...

    PostgreSQL 与 MySQL 比较

    ### PostgreSQL 与 MySQL 比较 #### 一、启动实例 ...综上所述,MySQL和PostgreSQL在许多方面都有相似之处,但也存在明显的区别。选择哪一种数据库系统取决于具体的应用场景、性能需求和个人偏好。

    MySQL、PostgreSQL、Oracle比较及数据库基础知识

    MySQL、PostgreSQL、Oracle比较; 数据库基础知识.ppt

    nacos2.1.0版,jar包,支持postgresql和mysql两种数据库

    在使用Nacos与PostgreSQL集成时,需要注意的是,PostgreSQL的语法和一些特性可能与MySQL略有不同,所以在配置Nacos和执行SQL脚本时要确保与数据库兼容。对于MySQL,由于其广泛使用,社区支持丰富,通常集成过程会...

    dbconvert_mysql_postgresql.zip

    标题“dbconvert_mysql_postgresql.zip”表明这是一款用于数据库转换的工具,主要功能是从PostgreSQL数据库转换到MySQL数据库。在IT行业中,数据迁移是常见的需求,尤其是在不同的数据库系统之间。PostgreSQL是一种...

    PostgreSQL与MySQL的比较研究初探.pdf

    《PostgreSQL与MySQL的比较研究初探》这篇文章探讨了两种主流的开源数据库系统——PostgreSQL和MySQL之间的差异,主要从标识列、字符串类型、JSP/Servlet开发中的中文处理、多平台支持和性能等方面进行了综合分析。...

    mysql2postgresql, 转换mysql模式到 PostgreSQL.zip

    mysql2postgresql, 转换mysql模式到 PostgreSQL mysql2postgresql转换mysql模式和数据到 PostgreSQL用法使用命令在xml格式中创建转储: mysqldump --xml -u USER_NAME DB_NAME> DUMP_FILE_NAME

    mysql转换postgresql工具

    国外大牛写的一个mysql数据库转换postgresql的脚本。亲试可以无错误运行。

    mybatis - 代码生成(postgresql\mysql)

    【标题】"mybatis - 代码生成(postgresql\mysql)" 涉及到的是MyBatis框架在数据库代码自动化生成方面的应用,针对PostgreSQL和MySQL两大主流关系型数据库。这个话题涵盖了数据库的逆向工程,以及生成的各类Java...

    PostgreSQL与mysql字段对比.docx

    本文档对比了PostgreSQL和MySQL的数据类型,包括BIT、BOOLEAN、CHAR、DATE、DATETIME、DECIMAL、FLOAT、INTEGER、TEXT、TIME、TIMESTAMP、VARCHAR等类型的详细说明。 BIT数据类型:在PostgreSQL中,BIT类型用于...

    nacos1.4.0部署包(兼容postgresql和mysql)

    nacos1.4.0部署包,可以直接在windows和linux运行,兼容mysql和postgresql。修改nacos源码请查看本文章:https://blog.csdn.net/zxfmamama/article/details/117293712

    PyPI 官网下载 | mysql2postgresql-0.3.0.tar.gz

    **MySQL与PostgreSQL** MySQL和PostgreSQL都是流行的开源关系型数据库管理系统。MySQL以其易用性和速度而受到欢迎,适合处理大量并发读写操作。PostgreSQL则以其强大的事务支持、复杂查询能力和ACID(原子性、一致性...

    PostgreSQL与mysql字段对比[总结].pdf

    - PostgreSQL的数据类型与MySQL类似,但有其独特的特点。例如,BIT和VARBIT支持位串,BYTEA用于存储大型二进制对象,BIGSERIAL和SERIAL则用于自增整数,而且提供了TIMESTAMP WITH TIME ZONE和WITHOUT TIME ZONE来...

    C#插件用于MySQL and PostgreSQL数据库驱动

    C#提供了ADO.NET(ActiveX Data Objects .NET)框架,它是一组用于访问数据的类库,允许开发者与多种数据库系统进行交互,包括MySQL和PostgreSQL。ADO.NET提供了如SqlConnection、SqlDataAdapter和SqlCommand等类,...

    PostgreSQL和MySQL存储层深度解析

    在讨论PostgreSQL与MySQL存储层的对比前,必须了解存储层涉及的几个关键性能指标:IO能力、稳定性、存储能力。 IO能力是衡量存储层性能的基础指标。PostgreSQL和MySQL在IO操作上有着不同的实现方式。PostgreSQL以页...

    MySQL与PostgreSQL数据库高可用分析实践.pdf

    MySQL与PostgreSQL数据库高可用分析实践 本文档详细介绍了MySQL和PostgreSQL数据库高可用的分析实践,涵盖了高可用原理、MySQL高可用和PostgreSQL高可用等方面的知识点。 一、高可用原理 高可用是指系统在无中断...

Global site tag (gtag.js) - Google Analytics