PostgreSQL(ポストグレス・キュー・エル)についてよくある質問とその解答(FAQ) 原文最終更新日: Fri Nov 16 10:53:50 EST 2007 現在の維持管理者: Bruce Momjian (bruce@momjian.us) Maintainer of Japanese Translation: Jun Kuwamura (juk at postgresql.jp) この文書の最新版は http://www.postgresql.org/docs/faqs.FAQ.html で見ることがで きます。 プラットホームに特有の質問については: http://www.postgresql.org/docs/faq/ に解答があります。 (以下、訳者による注釈を [訳注: と ] とで囲んで記します。) [訳注: 日本語版のFAQは、 http://www.postgresql.org/docs/faqs.FAQ_japanese.html にあります。 最新の日本語版については、この文書の最後にある「日本語版について」をごらんください。 ] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 一般的な質問 1.1) PostgreSQLとは何ですか?その呼び方は? Postgresとは何? 1.2) 誰が PostgreSQL をコントロールしていますか? 1.3) PostgreSQLの著作権はどうなってますか? 1.4) PostgreSQLをサポートするプラットホームは? 1.5) PostgreSQLはどこから入手できますか? 1.6) 最新のリリースはどれですか? 1.7) サポートはどこで受けられますか? 1.8) バグレポートはどのように発信しますか? 1.9) 既知のバグや未だ無い機能はどうやって見つけますか? 1.10) どのような文書がありますか? 1.11) SQLはどうすれば学べますか? 1.12) パッチを提供したり、開発チーム参加するにはどうすればよいですか? 1.13) 他のDBMSと比べてPostgreSQLはどうなのですか? 1.14) PostgreSQLは国毎の最新の夏時間の変更を扱いますか? ユーザ・クライアントの質問 2.1) PostgreSQL にはどんなインターフェースが使えますか? 2.2) PostgreSQL を Web ページと連携させるにはどんなツールがありますか? 2.3) PostgreSQL にグラフィカル・ユーザインターフェースはありますか? 管理上の質問 3.1) どうすれば、PostgreSQLを/usr/local/pgsql 以外の場所にインストールできます か? 3.2) 他のホストからの接続はどのように制御しますか? 3.3) より良い性能を得るためには、データベース・エンジンをどのように調整しますか ? 3.4) どのようなデバグ機能が使えますか? 3.5) 接続しようとするときに 'Sorry, too many clients' が出るのはなぜですか? 3.6) PostgreSQLのアップグレードの手順はどうなりますか? 3.7) ハードウェアにはどのようなコンピュータを使えばよいですか? 操作上の質問 4.1) 最初のいくつかのロウのみを select するにはどうしますか?ランダムなロウ? 4.2) 定義されたテーブル、インデックス、データベース、および、ユーザをどのように して見つけ出しますか? 4.3) カラムのデータタイプを変更するにはどうしますか? 4.4) ロウ、テーブル、データベースの最大サイズは? 4.5) 一般的なテキストファイルのデータを保存するには、データベースのディスク容量 はどのくらい必要ですか? 4.6) クエリが遅いのはなぜでしょう?なぜ、インデックスが使われないのでしょうか? 4.7) クエリオプティマイザが、どのようにクエリを評価していかを、見るにはどうしま すか? 4.8) 正規表現での検索や大文字と小文字とを区別しない正規表現検索はどのように実現 しますか?大文字と小文字とを区別しない検索のためのインデックスはどのように使い ますか? 4.9) クエリの中で、フィールドが NULL であることを検出するにはどうしますか? NULLの可能性のあるものをどのようすれば連結できますか? フィールドがNULLかどうか でどのようにソートができますか? 4.10) いろいろな文字型のそれぞれの違いは何ですか? 4.11.1) 通番(serial)/自動増分フィールドはどのようにつくりますか? 4.11.2) SERIALデータ型に挿入される値は、どうすれば得られますか? 4.11.3) currval() は他のユーザとの競合状態に陥ることはないですか? 4.11.4) トランザクションが中断したときにもういちどシーケンス番号が使われないの はなぜですか?シーケンス/SERIALカラムに空きがあるのはなぜですか? 4.12) OID とは何ですか? TID とは何ですか? 4.13) エラーメッセージ "ERROR: Memory exhausted in AllocSetAlloc()"が出るのはな ぜですか? 4.14) どのバージョンの PostgreSQL を走らせているのかを調べるにはどうしますか? 4.15) 現在の時刻がデフォルトとなるようなカラムはどのようにつくりますか? 4.16) 外部結合(outer join)はどのように実現しますか? 4.17) 複数のデータベースを使う問い合わせはどのようにすればできますか? 4.18) 関数から複数のロウまたはカラムを返すにはどうしますか? 4.19) PL/PgSQL の関数の中で一時テーブルにアクセスするとき、どうして "relation with OID ##### does not exist" というエラーを受け取るのでしょうか? 4.20) どのようなレプリケーションのソリューションがありますか? 4.21) テーブルとカラムの名前がクエリーの中で認識されないのはなぜですか?なぜ大 文字化(キャピタライズ)は温存されないのですか? 日本語に関する質問 5.1) 日本語がうまく扱えないのはなぜですか? 5.2) psql でWindowsからアクセスしたときに、日本語が文字化けするのですが? ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 一般的な質問 1.1) PostgreSQLとは何ですか?その呼び方は? Postgresとは何? PostgreSQLはPost-Gres-Q-L(ポスト・グレス・キュー・エル) と発音しますが、会話の 中では単純に Postgres と呼ばれることもあります。("PostgreSQL"をどう発音するか 気になる人のために、音声ファイルを用意してあります。 PostgreSQL はオブジェクト-リレーショナルデータベースシステムで、伝統的な商用デ ータベースシステムに、次世代DBMSシステムに見られるような改良が施された特徴を有 します。PostgreSQLは、無料で完全なソースコードを手に入れることができます。 PostgreSQL の開発は、ほとんどが、世界中にひろがったボランティアの開発者によって 、インターネットを通したコミュニケーションによって行われています。コミュニティ によるプロジェクトであるため、どの企業の制御もうけません。開発に参加したければ 、 http://www.postgresql.org/docs/faqs.FAQ_DEV.html にある開発者のFAQを見てくだ さい。 PostgresはPostgreSQLの広く使われている愛称です。また、バークレーでのプロジェク トでもともと使われていた名前で、ほかのいずれの愛称に比べても遥かに好ましいです 。'PostgreSQL' の発音が難しいと思うのであれば、そのかわりに 'Postgres' と呼ぶよ うにしましょう。 1.2) 誰が PostgreSQL をコントロールしていますか? PostgreSQLの門番、中央委員会、あるいは、コントロールをする会社を探そうとしても 、諦めざるをえず ---- 存在しないのです。我々は、中心となるコミッティとCVSコミッ タを持ちますが、これらのグループはコントロールするためというよりも、管理上のも のです。ここでは、プロジェクトは、だれでも参加ができる開発者とユーザのコミュニ ティにより方向付けられます。読者がやらなければならないことは、メーリングリスト をサブスクライブして、議論に参加することです。(Developer's FAQには、PostgreSQL 開発に加わり方についての情報があります。) 1.3) PostgreSQL の著作権はどうなってますか? PostgreSQL は下記の著作権に従います。 PostgreSQLは古くからのBSDライセンスの下で配布されています。それは基本的には、利 用者がそのコードを好き勝手に利用することが許されています。制限があるとすれば、 このソフトウェアに伴ういかなる問題においても法的に責任を我々に負わせることがで きないということです。また、この著作権表示がこのソフトウェアのすべての複製に表 示することも必要です。以下に、我々が実際に使っているBSD使用許諾書を示します: [訳注: 正文は英語です。参考として、訳文を併記掲載します。 ] PostgreSQL Data Base Management System Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group Portions Copyright (c) 1994-1996 Regents of the University of California Permission to use, copy, modify, and distribute this software and its documentation for any purpose, without fee, and without a written agreement is hereby granted, provided that the above copyright notice and this paragraph and the following two paragraphs appear in all copies. IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS. POSTGRESQL データベース管理システム 部分的著作権 (c) 1996-2007, PostgreSQL国際開発チーム 部分的著作権 (c) 1994-1996 カリフォルニア大学本校 本ソフトウェアおよびその文書一式は上記の著作権表示と、この文章 およびこれに続く二つの段落が全ての複製に添付されている限りにおい て、使用、複製、修正および配付の許可を、いかなる目的であっても、 無償でかつ同意書無しに行なえることをここに認めます。 カリフォルニア大学は、いかなる当事者にたいしても、利益の壊失を 含む、直接的、間接的、特別、偶然あるいは必然的にかかわらず生じた 損害について、たとえカリフォルニア大学がこれらの損害について訴追 を受けていたとしても、一切の責任を負いません。 カリフォルニア大学は、商用目的における暗黙の保証と、特定目的で の適合性に関してはもとより、これらに限らず、いかなる保証も放棄す ることを明言します。以下に用意されたソフトウェアは「そのまま」を 基本原理とし、カリフォルニア大学はそれを維持、支援、更新、改良あ るいは修正する義務を負いません。 [訳注: 著作権に関する正文は上記の英語による表記です。日本語訳はあくまで 参考程度としてください。 ] 1.4) PostgreSQLをサポートするプラットホームは? 一般的に、最近のUnix互換プラットホームであればPostgreSQLを稼働させられるはずで す。リリースの時点で実際にテストを行なったことの報告がなされたプラットホームに ついてはインストール手引書に列挙してあります。 PostgreSQL は、Win2000 SP4, WinXP, そして、Win2003 など Microsoft Windows NTベ ースのオペレーティングシステムで、ネイティブに走ります。あらかじめパッケージに されたインストーラが http://pgfoundry.org/projects/pginstaller にあり、利用でき ます。MSDOSベースのWindowsのバージョン(Win95, Win98, WinMe)では、Cygwinを使って PostgreSQL を走らせることができます。 [訳注 pgInstaller の入手はFTPミラーサイトの win32 ディレクトリからも可能です。 http://www.postgresql.org/mirrors-ftp.html 詳しくは、次の Windows版に関するFAQの和訳をごらんください。 http://old.postgresql.jp/wg/jpugdoc/FAQ_windows.ja.html ] 次のサイトに Novell Netware 6 への移植版もあります。 http://forge.novell.com ま た、OS/2 (eComStation) バージョンは、 http://hobbes.nmsu.edu/cgi-bin/h-search? sh=1&button=Search&key=postgreSQL&stype=all&sort=type&dir=%2Fにあります。 1.5) PostgreSQL はどこから入手できますか? Webブラウザ経由だと、 http://www.postgresql.org/ftp/、それから、ftp経由だと、 ftp://ftp.postgresql.org/pub/ を使います。 1.6) 最新のリリースはどれですか? PostgreSQL の最新版はバージョン 8.2.5 です。 我々は、1年毎にメジャーリリースを、数ヵ月ごとのマイナーリリースを行なうことを計 画しています。 [訳注 バージョン番号の x.y.z の最初の x.y がメジャーリリースの番号に相 当し、最後の z がマイナーリリースの番号になります。メジャーリリー スの番号が同じであれば、データベース・クラスタに互換性があります。 ] 1.7) サポートはどこで受けられますか? PostgreSQL コミュニティは多くのユーザのために、電子メール経由の支援を提供してい ます。電子メールリストをサブスクライブするためのメインとなるウェブサイトは http://www.postgresql.org/community/lists/です。これから、始めるのであれば general または、bugs といったリストがよいでしょう。 メジャーなIRC チャンネルは、Freenode (irc.freenode.net)の #postgresql というチ ャンネルです。UNIX コマンドでは、 irc -c '#PostgreSQL' "$USER" irc.freenode.net を使って参加できます。同じネットワークに、スペイン語のチャンネル (# postgresql-es)、フランス語のチャンネル (#postgresqlfr)、ブラジル語チャンネル (# postgresql-br) もあります。また、EFNetにもPostgreSQLチャンネルがあります。 [訳注: 1999年7月23日、日本ポストグレスユーザー会、略称JPUGが設立されました。 JPUG は非営利組織で、PostgreSQLを利用する人達の相互協力の場となっています。 (2006年 特定非営利活動(NPO)法人日本PostgreSQLユーザ会になりました。 Web会員と正会員の会費は無料ですが、協賛会員の会費と会員の貢献で 会は運営されています。) 詳しくは、JPUG のWeb サイト: http://www.postgresql.jp/ をごらんください。 日本語のIRCチャンネル '#PostgreSQL:*.jp' も存在します。 ] 商用サポート会社のリストは http://www.postgresql.org/support/ professional_supportにあります。 1.8) バグレポートはどのように発信しますか? http://www.postgresql.org/support/submitbug のPostgreSQL バグフォームを訪れてく ださい。バグレポートを提出する仕方についての手引と指針があります。 それと同時に ftp サイト ftp://ftp.postgresql.org/pub/ で、最新バージョンの PostgreSQL を探してみてください。 1.9) 既知のバグや未だ無い機能はどうやって見つけますか? PostgreSQLは拡張されたSQL:2003のサブセットをサポートします。我々のページの TODO リストに、既知のバグや欠落機能や将来計画についての記述があります。 特徴の要求は普通次のいずれかの解答の中にあります: ・ 既にここにある機能は、 TODO リストです ・ 次のような機能は目論まれていません。それは: □ SQL規格に準ずる既存の機能と重複するもの □ コードの複雑性ばかりを高めて、得るものが少ない機能 □ 安全性が確められない機能 ・ 新しい機能は、 TODO のリストに加えられられます。 我々は、PostgreSQL に関して、電子メールで直接対応して TODO リストを最新に更新し てゆくほうがより効果的であることを知っていますので、バグ追跡システムは使いませ ん。現実に、このソフトウェアの中でバグはそれほど長くはい続けませんし、多くのユ ーザに影響するバグは早急に修正されます。PostgreSQLのリリースで、すべての変更点 、改良点、そして、修正点を知りたければ、 CVS のログメッセージを見てください。リ リースノートにさえ、このソフトウェアに加えられたすべての変更点は網羅されていま せん。 1.10) どのような文書がありますか? 配付の中に、いくつかのマニュアルとオンライン・マニュアル(マニュアル・ページ)お よびいくつかの小さなテスト例題が含まれます。 /docディレクトリをごらんください。 また、マニュアルは、 http://www.postgresql.org/docs/でオンラインでも閲覧できま す。 [訳注: JPUG 文書・書籍関連分科会で翻訳されたマニュアルもあります。 http://www.postgresql.jp/document/pg825doc/ インプレスから、 PostgreSQLオフィシャルマニュアルとして出版されています。 ] オンラインで参照できる PostgreSQL の本も2冊あります。 http://www.postgresql.org /docs/books/awbook.html [訳注: この本は、JPUG「PostgreSQL Book翻訳分科会」 で翻訳され、ピアソンから 「はじめてのPostgreSQL」として出版されています。 ] および、 http://www.commandprompt.com/ppbook/です。 [訳注: 邦訳は「実践 PostgreSQL」 がオライリーから出版されています。 ] 購入可能な書籍の目録は、http://www.postgresql.org/docs/books/ にあります。 PostgreSQL 技術情報記事も、http://www.postgresql.org/docs/techdocs にあります。 [訳注: 日本語の書籍等については、日本PostgreSQLユーザ会の、http://www.postgresql.jp/PostgreSQL/references.html もごらんください。 ] コマンドラインのクライアントプログラムpsql にも、型、演算子、関数、集約、その他 の情報を調べるために、素晴らしい \d コマンドがいくつかあります。 \? を入力する と利用可能なコマンドが表示されます。 我々の Web サイトには、さらに沢山の文書があります。 1.11) SQL はどうすれば学べますか? まず、上記で述べた PostgreSQL についての本を読むことを検討してください。 The Practical SQL Handbook, Bowman Judith S. et al., Addison-Wesley も多くのユーザ に好評です。ほかでは、The Complete Reference SQL, Groff et al., McGraw-Hill も 好評です。 素晴らしい手引書は、 http://www.intermedia.net/support/sql/sqltut.shtm http://sqlcourse.com http://www.w3schools.com/sql/default.asp http://mysite.verizon.net/Graeme_Birchall/id1.html にあります。 [訳注: 日本PostgreSQLユーザ会の日本語の参考文献の紹介ページ http://www.postgresql.jp/PostgreSQL/references.html があります。 近藤直文氏の「初心者向のDB設計入門・SQL入門参考書紹介」のコーナー http://www.shonan.ne.jp/~nkon/ipsql/books_SQL.html があります(やや古い2000年版)。 堀田倫英氏の「PostgreSQL日本語マニュアル」 http://www.net-newbie.com/ ではオンラインマニュアルの検索ができます。 丸山不二夫氏のUNIX データベース入門 http://www.wakhok.ac.jp/DB/DB.html もオンラインで読むことができます。 Nikkei BP IT Pro にある石井達夫氏の PostgreSQL ウォッチ では毎回新しい情報をとりあげています。 ] 1.12) パッチを提供したり、開発チーム参加するにはどうすればよいですか? (開発者向けの)Developer's FAQをごらんください。 1.13) 他のDBMSと比べPostgreSQLはどうなのですか? ソフトウェアを計る方法にはいくつかあります。機能と性能と信頼性とサポートと価格 です。 機能(Features) PostgreSQLは、トランザクション、サブクエリ、トリガー、ビュー、外部キー整合 性参照、および、洗練されたロック機構など、大規模商用 DBMSが持つ機能をほとん ど持っています。さらに PostgreSQLは、ユーザ定義型、継承、ルール、それから、 ロック競合を縮小するマルチバージョン同時性制御など、商用DBMSも持ち合わせな いような機能をいくつか持ち合わせています。 性能(Performance) PostgreSQLは他の商用あるいはオープンソースのデータベースと互角の性能も持ち ます。ある面ではより早かったり、ほかの面ではより遅かったりします。他のデー タベースに比べた性能は、ふつう +/-10% くらいでしょう。 信頼性(Reliability) 我々は、DBMSの信頼性が高くなくてはその価値が無いことを理解してます。十分テ ストして、安定したコードをバグを最小にしてからリリースするように努めてます 。それぞれのリリースは少なくとも1 カ月以上のベータ・テストを行ない、これま でのリリースの履歴が、製品版として安定した堅固なリリースであることを物語っ ています。この分野では、他のデータベースと比べても遜色がないことに自信を持 っています。 サポート(Support) 我々のメーリングリストは、遭遇するいかなる問題についても解決への手助けをし てくれる、開発者やユーザの大きな集まりへの接点を提供しています。我々は問題 の解決を保証することはできませんが、商用データベースであっても常に解決され るわけではありません。開発者や、ユーザ・コミュニティ、マニュアル類、それに 、ソースコードなどへ直接アクセスできることによって、PostgreSQLのサポートは 、他のDBMS サポートよりも優れたものとなっています。御要望に答えて、事柄毎の 商用サポートなどもあります(FAQ1.7節をごらんください)。 価格(Price) PostgreSQLの利用は、商用でも非商用でも、すべて無料です。上記に示してあるBSD スタイルの使用許諾に外れない限り、PostgreSQLのコードを制限無しで商品に組み 込むことができます。 1.14) PostgreSQLは国毎の最新の夏時間の変更を扱いますか? 合州国の夏時間の変更は、PostgreSQLのリリース8.0.4以降[4+]と、その後のメジャーリ リース、たとえば 8.1 には含まれています。カナダとオー西部ストラリアの変更は、 8.0.[10+], 8.1.[6+] および、その後のメジャーリリースのすべてに含まれます。8.0よ り前のPosrgreSQLではオペレーティングシステムのタイムゾーンデータベースを夏時間 情報のために使っています。 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ユーザ・クライアントの質問 2.1) PostgreSQL にはどんなインターフェースが使えますか? PostgreSQL のインストールに含まれる物はCと組込み Cのインターフェースだけです。 その他のインターフェースは独立したプロジェクトで、別々にダウンロードされます。 分かれることで、それぞれの開発チームが独自のリリーススケジュールを持つことが許 されます。 PHP のようないくつかのプログラミング言語は、 PostgreSQLのインターフェースを含ん でいます。Perl, TCL, Python, そして、そのほかの利用可能な言語のインターフェース は、 a href="http://pgfoundry.org">http://pgfoundry.org の Drivers/Interfaces の節の中とインターネットの検索でみつけられます。 2.2) PostgreSQL を Web ページと連携させるにはどんなツールがありますか? データベースを裏に持つ Web ページについての素晴らしい紹介が、 http://www.webreview.comにあります。 Web への拡張のためには、PHP(http://www.php.net/) が卓越したインターフェースとな っています。 [訳注: PHPに関する日本語の情報は、2000年4月19日に発足した日本PHPユーザ会のサイト http://www.php.gr.jp/ あるいは、廣川 類さんのサイト http://www.geocities.jp/rui_hirokawa/php/ にかなりまとめられています。 ] 処理が複雑な場合、多くの人は Perl インターフェースと CGI.pm か mod_perl を使い ます。 2.3) PostgreSQL にグラフィカル・ユーザインターフェースはありますか? 商用とオープンソース開発者によるもの両方で、PostgreSQLには多くのGUIツールが利用 可能で、詳細なリストは、PostgreSQLコミュニティ文書でごらんください。 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 管理上の質問 3.1) どのようにすれば /usr/local/pgsql 以外の場所にインストールできますか? 簡単な方法は、 configure を走らせるときに --prefix オプションを指定することです 。 3.2) 他のホストからの接続はどのように制御しますか? 既定値では、PostgreSQL は Unix ドメインソケット、または、TCP/IP接続のローカルマ シンからの接続しか許しません。postgresql.conf の中の listen_addresses を修正し 、かつ、$PGDATA/pg_hba.conf ファイルを適切に直し、データベースサーバを再起動し て、ホストベースの認証を有効にしないかぎりは、他のマシンからは接続できないでし ょう。 3.3) より良い性能を得るためには、データベース・エンジンをどのように調整しますか ? 性能改善の可能性のありそうな主な領域が3つあります: クエリの変更 クエリを修正してより良い性能を得ることを含みます: □ 式および部分インデックスを含む、インデックスを作成 □ 複数のINSERTのかわりにCOPYを使用 □ 複数の文をグループ化し、1つのトランザクションにしてコミットのオーバヘッ ドを削減 □ インデックスからから沢山のロウを取り出すときはCLUSTERを使用 □ クエリの出力のサブセットを返すためにLIMITを使用 □ 準備されているクエリを使用 □ オプティマイザの正確な統計を維持するためにANALYZEを使用 □ VACUUM または pg_autovacuum の常用 □ 大きなデータ変更のあるときはインデックスを削除 サーバ構成 postgresql.confの設定のいくつかは性能に影響します。詳しくは、 Administration Guide/Server Run-time Environment/Run-time Configuration の 全件リストをごらんください( JPUGサイトの日本語版、サーバの構成)。そして、解 説として、 http://www.varlena.com/varlena/GeneralBits/Tidbits/ annotated_conf_e.html および、 http://www.varlena.com/varlena/GeneralBits/ Tidbits/perf.html をごらんください。 ハードウェアの選定 性能におけるハードウェアの影響は http://www.powerpostgresql.com/PerfList/ と、 http://momjian.us/main/writings/pgsql/hw_performance/index.html (JPUG サイトの日本語版) に述べられています。 [訳注: JPUG理事長の片岡裕生氏による、「今すぐできるPostgreSQLチューニング」 というコーナーが ThinkIT サイトにあり、実作業の参考になります。 http://www.thinkit.co.jp/free/tech/10/1/1.html ] 3.4) どのようなデバグ機能が使えますか? サーバ構成変数には多くの log_* があり、クエリとプロセスの統計を出力することがで き、デバグと性能計測にとても便利です。 3.5) 接続しようとするときに 'Sorry, too many clients' が出るのはなぜですか? 既定での制限である 100 のデータベースセッションに達してしまっています。サーバー の同時接続できるバックエンドプロセスの制限値を増やす必要があります。 postgresql.conf の中のmax_connections の値を変更してサーバを再起動することで可 能になります。 3.6) PostgreSQLのアップグレードの手順はどうなりますか? バージョン番号付けの方針について、更新全般についての解説はhttp:// www.postgresql.org/support/versioning を、そして、アップグレードについての一般 的な説明は http://www.postgresql.org/docs/current/static/install-upgrading.html をご覧ください。 [訳注: アップグレードについての和訳版は下記にあります。 http://www.postgresql.jp/document/current/html/install-upgrading.html ] [訳注: 原文では、下記の内容は独立したページに移され、削除されています。 新しい機能を盛り込むPostgreSQLのメジャーリリースはだいたい年に1回程度行ないます 。メジャーリリースは、たとえば、8.1から8.2へのように、バージョン番号の1番目か2 番目の部分を増やしてゆきます。 PostgreSQLのメジャーリリースは通常、システムテーブルとデータの内部フォーマット を変更します。これらの変更はたいていは複雑なのでで、データファイルの後方互換性 を維持したりはしません。メジャーアップグレードのためには、データベースのダンプ/ リロードが必要になります。 マイナーリリースは、たとえば、8.1.5 から8.1.6へのように、バージョン番号の3番目 の値を増やします。PostgreSQLチームは、マイナーリリースに対しては、バグフィクス しか行ないません。すべてのユーザは、できるだけ最新のマイナーリリースに更新すべ きです。アップグレードには、常にリスクがつきものですから、PostgreSQLのマイナー 修正リリースでは、頻繁に発生したり、セキュリティに関係したり、データがつぶれる バグだけを修正し、アップグレードのリスクを最小限にとどめます。我々のコミュニテ ィでは、アップグレードするリスクよりも、アップグレードしないリスクのほうが高い と考えています。 マイナーリリースのアップグレードにはダンプとリストアの必要はなく、データベース サーバを停止して、アップデートされたバイナリをインストールし、サーバをリスター トします。 ] 3.7) ハードウェアにはどのようなコンピュータを使えばよいですか? PCハードウェアはほとんど互換性がありますので、ほとんどの人は、すべてのPCハード ウェアが同じ品質だと思い込む傾向があります。しかし、それは間違いです。ECC RAM、 SCSI、および、高品質マザーボードは、安いハードウェアに比べると、より信頼性が高 く、より性能も良いのです。 PostgreSQL はほとんどのハードウェアで稼働しますが、 信頼性や性能が重要な場合は、使用中のハードウェアのオプションについて調査するこ とが賢明です。我々のメーリングリスト上でもハードウェアオプションのトレードオフ について議論することができます。 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 操作上の質問 4.1) 最初の数ロウのみを SELECTするにはどうしますか?ランダムなロウ? たったの数行のロウを取り出すために、何行必要かがわかれば、 SELECT のときに LIMIT を使います。 ORDER BYにインデックスがマッチした場合、まったくクエリが実行 されないこともあります。SELECT のときに何行が必要かを知らなければ、カーソルを使 いFETCHします。 ランダムロウをSELECTするには、次の文を使います: SELECT col FROM tab ORDER BY random() LIMIT 1; 4.2) 定義されたテーブル、インデックス、データベース、および、ユーザをどのように して見つけ出しますか?psqlで使われているクエリを表示するにはどうしますか? psql の中で \dtコマンドを使ってテーブルを見ることができます。psqlの中で \? を使 って、コマンドの全リストを調べることができます。一方で、psql のソースコードで、 バックスラッシュコマンドを出力する pgsql/src/bin/psql/describe.c ファイルを読む こともできます。その中には、 SQL コマンドを生成する部分も含まれます。また、 -E オプションを付けて psql を開始すると、入力されたコマンドを実行するためのクエリ を印字出力するようになります。 PostgreSQLは SQL 準拠の INFORMATION SCHEMA イン ターフェースを提供しますので、データベースについての情報を問い合わせることもで きます。 pg_ で始まるシステムテーブルでもこれらを記述することができます。 psql -lを使うと全てのデータベースをリストします。 それと、pgsql/src/tutorial/syscat.source を試してみてください。そこには、データ ベースのシステムテーブルから情報を得るために必要な SELECT 文が沢山あります。 4.3) カラムのデータ型を変更するにはどうしますか? カラムのデータ型の変更は 8.0 以降では、 ALTER TABLE ALTER COLUMN TYPE を使うこ とにより間単になりました。 それより前のバージョンでは、以下のようにします: BEGIN; ALTER TABLE tab ADD COLUMN new_col new_data_type; UPDATE tab SET new_col = CAST(old_col AS new_data_type); ALTER TABLE tab DROP COLUMN old_col; COMMIT; これを行なったときは、抹消された行が使っているディスク空間を回収するために VACUUM FULL tabをしたほうが良いかもしれません。 4.4) ロウ、テーブル、データベースの最大サイズは? 制限は以下のとおりです: データベースの最大サイズ? 制限無し (32 TB のデータベースも存在しま す) テーブルの最大サイズ? 32 TB ロウの最大サイズ? 400 GB フィールドの最大サイズ? 1 GB テーブル内での最大ロウ数? 制限無し テーブル内での最大カラム数? カラムの型によって 250-1600 テーブル内での最大インデックス 制限無し 数? もちろん、これらは実際は無制限ではなく、ディスク容量とメモリーやスワップスペー スの大きさにより制限されます。性能はこれらの値がことのほか大きな時に煽りを受け ます。 最大テーブルサイズの32TBはオペレーティングシステムによる巨大ファイルのサポート は必要としません。巨大なテーブルは複数の1GBのファイルに分けて保存されますので、 ファイルシステムの制限は重要ではありません。 デフォルトのブロックサイズを32kに増加することで、最大テーブルサイズと行サイズと 最大カラム数とを4倍にすることができます。また、最大テーブルサイズはテーブルパー ティションを使って増やすこともできます。 ひとつの制限は、約2,000文字以上の長さのカラムにインデックスを付けることができな いことです。幸いにも、そのようなインデックスは実際は必要ありません。長いカラム のMD5ハッシュの関数インデックスは一意性がなによりの保険で、また、フルテキストの インデックスではカラム内の単語を検索することができます。 4.5) 一般的なテキストファイルのデータを保存するには、データベースのディスク容量 はどのくらい必要です? 普通のテキストファイルを PostgreSQL のデータベースに保存するには、最大で約5倍の ディスク容量を必要とします。 例題として、各行に整数とテキスト記述を持つ 100,000行のファイルを考えてみましょ う。テキストの文字列の平均長さを20バイトと仮定すると、フラットファイルの大きさ は約2.8MB です。このデータを含む PostgreSQL データベースファイルの大きさは次の ように約5.2MBと見積もることができます: 24 bytes: 各ロウのヘッダ(概算) 24 bytes: 整数(int)フィールドとテキスト(text)フィールド + 4 bytes: ページ上のタップルへのポインタ ---------------------------------------- 52 bytes per row PostgreSQL のデータページサイズは 8192バイト(8KB)なので: 8192 bytes per page ------------------- = 146 rows per database page (切り捨て) 52 bytes per row 100000 data rows -------------------- = 633 database pages (切り上げ) 158 rows per page 633 database pages * 8192 bytes per page = 5,185,536 bytes (5.2 MB) インデックスは、これほどのオーバヘッドは要求しませんが、インデックス付けされる データを含む以上、それなりに大きくなります。 NULLはビットマップとして保存されていて、それらがわずかにスペースを使います。 4.6) クエリが遅いのはなぜでしょう?なぜ、インデックスが使われないのでしょうか? インデックスは、すべてのクエリで使われるわけではありません。テーブルが最小サイ ズより大きく、クエリでそのわずかなパーセンテージのロウを選択する時だけ、インデ ックスは使われます。これはインデックススキャンにより起こされるランダムなディス クアクセスは、テーブルをストレートに読む順次走査よりも遅くなることがあるからで す。 インデックスを使うかを決定するために、PostgreSQL はテーブルについての統計情報を 持たなければなりません。この統計情報は、 VACUUM ANALYZEまたは、単に ANALYZE を 使って収集することができます。統計情報を使ってオプティマイザはテーブルの中にあ るロウ数を知り、インデックスを使うべきかの決定をより正しくできます。統計情報は 最適な結合順や結合方法を決める上でも貴重なものもあります。統計情報の収集は、テ ーブルの内容が変わる毎に繰返しなされるべきです。 インデックスは、通常 ORDER BY や結合を行なうためには使われません。順次スキャン に続く明示的ソートは、巨大なテーブルのインデックススキャンよりも普通は高速です 。 しかし、ORDER BYと組み合わされたLIMIT は、テーブルの小さな部分を返すためにたび たびインデックスを使うでしょう。 もし、オプティマイザが間違ってシーケンシャルスキャンを選択したことに疑いがなけ れば、SET enable_seqscan TO 'off'に設定して、クエリをもう一度実行し、インデック ススキャンがまちがいなく速くなっているかどうかをみてください。 LIKE あるいは ~ のようなワイルドカード演算子は特別な環境でしか使えません: ・ 検索文字列が文字列の最初にききます。たとえば: □ LIKE パターンが%で始まらない □ ~ (正規表現) パターンは^で始まらなければならない ・ 検索文字列を文字クラスから始めることはできません。たとえば、[a-e]。 ・ ILIKE や ~* のような大文字と小文字を区別しない検索は使えません。そのかわり 、このFAQの4.8節で説明する式インデックスが使えます。 ・ initdb においては、デフォルトでCロケールが使われなくてはなりません。その理 由は、Cロケール以外では次に大きな文字を知ることができないからです。このよう な場合、 LIKE インデクシングにだけ働くような、特別な text_pattern_ops インデックスを作成することもできます。また、それを全文検索のフルテキストの インデックス作成に使うことができます。 4.7) 問い合わせオプティマイザがどのように問い合わせを評価するのかを見るにはどう しますか? オンラインマニュアルで EXPLAIN を見てください。 4.8) 正規表現での検索や大文字と小文字とを区別しない正規表現検索はどのように実現 しますか?大文字と小文字とを区別しない検索のためのインデックスはどのように使い ますか? ~演算子は正規表現照合を行ない、~* は大文字と小文字を区別しない (case-insensitive)正規表現照合を行います。大文字と小文字を区別しない LIKE 演算 子を ILIKE といいます。 大文字と小文字を区別しない等値比較は次のように表現できる: SELECT * FROM tab WHERE lower(col) = 'abc'; 標準インデックスでは使われず、しかしながら、もし、式インデックスを作ったならそ れが使われるでしょう。 CREATE INDEX tabindex ON tab (lower(col)); 上記のインデックスがUNIQUEで作成された場合、カラムは大文字と小文字を格納できま すが、その違いが文字ケースだけであっても同一にはなりません。あえて特定の文字ケ ースをカラムに格納するには CHECK制約か、トリガーを使ってください。 4.9) クエリの中で、フィールドがNULL であることを検出するにはどうしますか? NULL であることを検出するにはどうしますか?フィールドがNULLかどうかでどのようにソー トができますか? 以下のように、IS NULL と IS NOT NULLで、そのカラムをテストしてみます: SELECT * FROM tab WHERE col IS NULL; NULLの可能性のあるものを連結するには、COALESCE()を次のように使います。 SELECT COALESCE(col1, '') || COALESCE(col2, '') FROM tab NULL状態でソートするには、IS NULL と IS NOT NULL の修飾子を ORDER BY 句の中で使 ってみます。true のものは false のものよりも高い値として並べられますので、次の 例では NULL の記載が結果リストの上部に置かれます。 SELECT * FROM tab ORDER BY (col IS NOT NULL) 4.10) いろいろな文字型のそれぞれの違いは何ですか? 型 内部名 備考 VARCHAR(n) varchar 最大長のサイズを指定する、詰め物無し CHAR(n) bpchar 指定された固定長となるように空白が詰められる TEXT text 長さに特別な上限は無し BYTEA bytea 可変長のバイト配列(null-byte safe) "char" char 1文字 内部名にお目にかかるのは、システム・カタログを調べるときや、エラーメッセージを 受け取るときです。 上記の型のうち最初の4つの型は "varlena" 型です(すなわち、ディスクの最初の4バ イトがデータ長で、それの後に実際のデータが続きます)。このように実際の空間は宣言 された大きさよりも少し大きくなります。しかし、長い値は圧縮されるので、ディスク 上の空間は思ったよりも小さくなります。 VARCHAR(n) は可変長の文字列を保存するのに最適ですが、保存できる文字列の長さに制 限があります。TEXT は長さに制限の無い文字列の保存のためのもので、最大で 1ギガバ イトです。 CHAR(n)は、VARCHAR(n)が与えられた文字だけを保存するのに対し、ブラン クを詰め込んでいつも同じ長さで文字列を保存するのに最適です。BYTEAは、部分的に NULL のバイトを含むバイナリデータを保存するためのものです。これらのタイプは同じ くらいの性能特性をもちます。 4.11.1) 通番(serial)/自動増分フィールドはどのようにつくりますか? PostgreSQL は SERIAL データ型をサポートします。カラム上にシーケンスを自動作成し ます。たとえば、 CREATE TABLE person ( id SERIAL, name TEXT ); は自動的に次のように翻訳されます: CREATE SEQUENCE person_id_seq; CREATE TABLE person ( id INT4 NOT NULL DEFAULT nextval('person_id_seq'), name TEXT ); [訳注: CREATE UNIQUE INDEX person_id_key ON person ( id ); は、 7.3 以降は自動的には行なわれなくなりました。 ] 自動的につくられる通番は、