LoginSignup
96
84

PostgreSQL vs MySQL: その違いとは

Last updated at Posted at 2022-05-27

MySQL と PostgreSQL は多くの同じ機能と特徴を備えていますが、この2つのリレーショナルデータベース管理システム(RDBMS)には無視できない決定的な違いがあります。

これらの違いについてよくご存じない方のために、簡単に概要を説明します:

  • MySQL は読み取り専用のコマンドを管理するのに適しています。MySQLは読み取り専用のコマンドを管理するのに適しています。
  • PostgreSQLは、読み書き操作、大きなデータセット、複雑なクエリを管理するのに適しています。PostgreSQLは、読み書き操作や複雑なクエリを管理するのに適していますが、読み取り専用操作には適していません。
  • MySQLはPostgreSQLよりも少ない機能しか提供しませんが、そのおかげでMySQLは軽量で安定性が高く、処理速度が速いのです。
  • PostgreSQLは最初からACIDに準拠するように構築されており、同時実行トランザクション(MVCC)が必要な場合に最適ですが、読み取り専用操作に関しては遅く、安定性に欠けます。
  • MySQLはさまざまなタイプのデータストレージエンジンと高い互換性を持っています。一方、PostgreSQLは多くの異なるNoSQLフォーマットと高い互換性を持っています。

このガイドでは、各データベースシステムの簡単な歴史と概要を説明します。また、MySQLとPostgreSQLの決定的な相違点と類似点、そして使用ケースによってどちらが最適かを紹介します。

機能の比較 MySQL PostgreSQL
ORDBMSとRDBMSの比較 リレーショナルデータベース管理システム(RDBMS) オブジェクトリレーショナルデータベース管理システム(ORDBMS)
ACIDコンプライアンス ほとんどのエンジンはACIDコンプライアンスを提供しているが、MyISAMはACIDをサポートしていない。 完全サポート
バックアップとリカバリ バックアップとリカバリ機能を提供 効率的なバックアップとリカバリ機能でよく知られている
クロスプラットフォーム 対応 UNIXベースのシステムに最適
拡張機能とプラグイン 多数あり 拡張性で有名なPostGISなど
外部キー サポートされているが、MyISAMではサポートされていない。 完全サポート
インデックス作成テクニック 様々なテクニックが利用可能標 GINやGiSTのような高度な型を提供
SQLデータ型 準的な型が利用可能 より多様で、配列、hstoreを含む
ストアドプロシージャ サポートあり PL/pgでより高度にSQL言語トリガー
トリガービュー サポートあり 柔軟な多言語サポート
ビュー サポートあり マテリアライズド・ビュー
ユースケース MySQL PostgreSQL
ウェブアプリケーション スピードと信頼性で広く知られている 特に複雑なユースケースで人気上昇中
。。。 。。。 。。。

目次

  • 基本: PostgreSQLとMySQLの概要
  • 同じ、同じ、でも違う: MySQLとPostgreSQLの共通点(そしてユニークな点)は?
  • PostgreSQLよりMySQLを使用する場合、またその逆は?
  • PostgreSQLのユーザー・サポートとMySQLのユーザー・サポート
  • PostgreSQLのスピードとMySQLのスピード:どちらが速いか?
  • PostgreSQLとMySQLはどのプログラミング言語をサポートしていますか?
  • PostgreSQLとMySQLはどのオペレーティング・システムで動作しますか?
  • PostgreSQLのインデックスとMySQLのインデックス: どのようにインデックスを作成するのか?
  • PostgreSQLとMySQLのコーディングの違いは?
  • 2020年以降のPostgreSQLとMySQLの最新動向
  • 記事の概要

基本: PostgreSQL と MySQL の概要。。。

本ブログの続きは以下のリンクからご覧ください。
PostgreSQLとMySQLの決定的な違い

96
84
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
96
84