Manual:Revision table/ja

revision テーブル は、wiki の中でページにされたすべての編集のためにメタデータを保持します. すべてのページの編集はリビジョンレコードを生成し、そしてそれは編集をした利用者、編集がされた時間、及び、新しい wiki テキストへの参照のような情報を text テーブルの中に保持します.

ここで留意すべきは、レコードは新しい wiki テキストの一部が編集操作についてであり、一部がその編集操作の結果である事です. それは古い wiki テキストに参照を与えません.

別の wiki からのページの最後のリビジョンのインポートは、Revision テーブルの中に２つのエントリーを作りますが、1つは日付とインポートされたリビジョンの wiki テキストで、もう1つはインポートの日付です. 現在のページになる最新の wiki テキストは、同じ名前のページが既に存在している場合には、2つのページのなかで、より最近のものです.

revision テーブル は Recentchanges テーブルに非常に類似しています. Revision テーブル は ページの履歴 と 利用者の投稿記録 リストのために使用されます. Recentchanges テーブル は、最近更新したページ、リンク先の更新状況、ウォッチリスト、そしてページが生成された場合の 特別:新しいページ のために使用されます.

差分のインクルード:
 * Recentchanges テーブルはページの過去のリビジョンも参照します.
 * Recentchanges テーブルはページの移動と削除のようなログイベントも記録します.
 * Recentchanges テーブルの項目は定期的に消去されます; Revision テープル でのそれらは通常ではもっと長く、あるいはいつまでも保持されます.
 * 説明の通り、ページリビジョンの インポート がインポート日付のみで Revision テーブルへのエントリーを加えるだけではありませんが、しかしオリジナルの日付のものもあります.

Deleted revisions are moved to the archive table.

rev_id
このフィールドはそれぞれのリビジョンのために主キーを保持します. page_latest is a foreign key to this field.

rev_page
このフィールドはリビジョンに関係する page テーブル の参照を保持します. このフィールドの中の番号は当該のページの page_id フィールドと等しくなります. これは決して無効であるべきではありません.

rev_text_id
これは、実際の大量のテキストが保管されている Text テーブルの中の old_id  へのポインタです. 複数のリビジョンで同じテキストを使うことは可能です. &mdash; 例としては、メタデータのみが改訂出来る、あるいは以前のバージョンにロールバックされるリビジョンです.

rev_comment
このフィールドは編集者の 編集内容の要約 (編集者のリビジョンでのコメント) を保持します. このテキストは、履歴と、利用者の投稿記録 で表示されます. ( Recentchanges テーブル は 最近更新したページ、リンク先の更新状況、ウォッチリスト、そしてページが生成された場合での 新規ページのリストで使用するためのコピーを格納します. ) それは、不適切な部分を削除された wiki マークアップのサブセットでレンダリングされます.

rev_user
これは、編集をした利用者の user_id と同じで. このフィールドは、匿名の編集、初期化スクリプト、そして一部のまとまったインポートで 0 の値になります.

rev_user_text
このフィールドは編集者の利用者名のテキスト、あるいはリビジョンが無登録の利用者によってされた場合は編集者の IP アドレスを保持します.

In anonymous revisions imported from UseModWiki or early incarnations of the Phase II software, this field may contain an IP address with the final octet obscured (i.e.  such as 24.150.61.xxx; see bug 3631). Some edits imported from UseModWiki may contain a Reverse DNS lookup hostname like  or.

rev_timestamp
編集の タイムスタンプ を保持します.

rev_minor_edit
利用者が 'これは細部の編集です' チェックボックスにマークをしたかどうか記録します. このフィールドの値が 1 である場合、編集は '細部の編集' として申告されています. ; それ以外は 0 です.

rev_deleted
このフィールドは RevisionDelete システムに予約されています.

rev_len
このフィールドはリビジョンの長さを、バイト単位で格納します. 履歴ページで使用されています. Corresponds to rc_new_len.

rev_parent_id
このフィールドはツリー構造 (The Adjacency List Model) のサポートを追加するために使用されます. Corresponds to rc_last_oldid.

rev_sha1
This field is used to add the SHA-1 text content hash in base-36.

rev_content_model
Content model, see CONTENT_MODEL_XXX constants

rev_content_format
content format, see CONTENT_FORMAT_XXX constants

スキーマ概要
mysql> describe revision; ++-+--+-+++ ++-+--+-+++ ++-+--+-+++ 14 rows in set (0.00 sec)
 * Field             | Type                | Null | Key | Default        | Extra          |
 * rev_id            | int(10) unsigned    | NO   | PRI | NULL           | auto_increment |
 * rev_page          | int(10) unsigned    | NO   | MUL | NULL           |                |
 * rev_text_id       | int(10) unsigned    | NO   |     | NULL           |                |
 * rev_comment       | tinyblob            | NO   |     | NULL           |                |
 * rev_user          | int(10) unsigned    | NO   | MUL | 0              |                |
 * rev_user_text     | varbinary(255)      | NO   | MUL |                |                |
 * rev_timestamp     | binary(14)          | NO   | MUL |                |                |
 * rev_minor_edit    | tinyint(3) unsigned | NO   |     | 0              |                |
 * rev_deleted       | tinyint(3) unsigned | NO   |     | 0              |                |
 * rev_len           | int(10) unsigned    | YES  |     | NULL           |                |
 * rev_parent_id     | int(10) unsigned    | YES  |     | NULL           |                |
 * rev_sha1          | varbinary(32)       | NO   |     |                |                |
 * rev_content_model | varbinary(32)       | YES  |     | NULL           |                |
 * rev_content_format | varbinary(64)      | YES  |     | NULL           |                |

DESCRIBE revision により、MediaWiki 1.19 においては下記の内容を示します: mysql> describe mw_revision; ++-+--+-+-++ ++-+--+-+-++ ++-+--+-+-++ 12 rows in set
 * Field         | Type                | Null | Key | Default | Extra          |
 * rev_id        | int(8) unsigned     | NO   | PRI | NULL    | auto_increment |
 * rev_page      | int(8) unsigned     | NO   | PRI | NULL    |                |
 * rev_text_id   | int(8) unsigned     | NO   |     | NULL    |                |
 * rev_comment   | tinyblob            | NO   |     | NULL    |                |
 * rev_user      | int(5) unsigned     | NO   | MUL | 0       |                |
 * rev_user_text | varbinary(255)      | NO   | MUL | NULL    |                |
 * rev_timestamp | binary(14)          | NO   | MUL | NULL    |                |
 * rev_minor_edit | tinyint(1) unsigned | NO  |     | 0       |                |
 * rev_deleted   | tinyint(1) unsigned | NO   |     | 0       |                |
 * rev_len       | int(8) unsigned     | YES  |     | NULL    |                |
 * rev_parent_id | int(8) unsigned     | YES  |     | NULL    |                |
 * rev_sha1      | varbinary(32)       | NO   |     | NULL    |                |

DESCRIBE revision により、MediaWiki 1.18 においては下記の内容を示します: mysql> describe mw_revision; ++-+--+-+-++ ++-+--+-+-++ ++-+--+-+-++ 11 rows in set
 * Field         | Type                | Null | Key | Default | Extra          |
 * rev_id        | int(8) unsigned     | NO   | PRI | NULL    | auto_increment |
 * rev_page      | int(8) unsigned     | NO   | PRI | NULL    |                |
 * rev_text_id   | int(8) unsigned     | NO   |     | NULL    |                |
 * rev_comment   | tinyblob            | NO   |     | NULL    |                |
 * rev_user      | int(5) unsigned     | NO   | MUL | 0       |                |
 * rev_user_text | varbinary(255)      | NO   | MUL | NULL    |                |
 * rev_timestamp | binary(14)          | NO   | MUL | NULL    |                |
 * rev_minor_edit | tinyint(1) unsigned | NO  |     | 0       |                |
 * rev_deleted   | tinyint(1) unsigned | NO   |     | 0       |                |
 * rev_len       | int(8) unsigned     | YES  |     | NULL    |                |
 * rev_parent_id | int(8) unsigned     | YES  |     | NULL    |                |

DESCRIBE revision により、MediaWiki 1.11 においては下記の内容を示します: mysql> describe mw_revision; ++-+--+-+-++ ++-+--+-+-++ ++-+--+-+-++ 11 rows in set
 * Field         | Type                | Null | Key | Default | Extra          |
 * rev_id        | int(8) unsigned     | NO   | PRI | NULL    | auto_increment |
 * rev_page      | int(8) unsigned     | NO   | PRI | NULL    |                |
 * rev_text_id   | int(8) unsigned     | NO   |     | NULL    |                |
 * rev_comment   | tinyblob            | NO   |     | NULL    |                |
 * rev_user      | int(5) unsigned     | NO   | MUL | 0       |                |
 * rev_user_text | varchar(255)        | NO   | MUL | NULL    |                |
 * rev_timestamp | char(14)            | NO   | MUL | NULL    |                |
 * rev_minor_edit | tinyint(1) unsigned | NO  |     | 0       |                |
 * rev_deleted   | tinyint(1) unsigned | NO   |     | 0       |                |
 * rev_len       | int(8) unsigned     | YES  |     | NULL    |                |
 * rev_parent_id | int(8) unsigned     | YES  |     | NULL    |                |

DESCRIBE revision により、MediaWiki 1.9 においては下記の内容を示します: mysql> describe mw_revision; ++-+--+-+-++ ++-+--+-+-++ ++-+--+-+-++ 9 rows in set
 * Field         | Type                | Null | Key | Default | Extra          |
 * rev_id        | int(8) unsigned     | NO   | PRI | NULL    | auto_increment |
 * rev_page      | int(8) unsigned     | NO   | PRI | NULL    |                |
 * rev_text_id   | int(8) unsigned     | NO   |     | NULL    |                |
 * rev_comment   | tinyblob            | NO   |     | NULL    |                |
 * rev_user      | int(5) unsigned     | NO   | MUL | 0       |                |
 * rev_user_text | varchar(255)        | NO   | MUL | NULL    |                |
 * rev_timestamp | char(14)            | NO   | MUL | NULL    |                |
 * rev_minor_edit | tinyint(1) unsigned | NO  |     | 0       |                |
 * rev_deleted   | tinyint(1) unsigned | NO   |     | 0       |                |

Indices
mysql> show index in revision; +--++-+--+---+---+-+--++--++-+---+ +--++-+--+---+---+-+--++--++-+---+ +--++-+--+---+---+-+--++--++-+---+ 13 rows in set (0.02 sec)
 * Table   | Non_unique | Key_name            | Seq_in_index | Column_name   | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
 * revision |         0 | PRIMARY             |            1 | rev_id        | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         0 | rev_page_id         |            1 | rev_page      | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         0 | rev_page_id         |            2 | rev_id        | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         1 | rev_timestamp       |            1 | rev_timestamp | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         1 | page_timestamp      |            1 | rev_page      | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         1 | page_timestamp      |            2 | rev_timestamp | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         1 | user_timestamp      |            1 | rev_user      | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         1 | user_timestamp      |            2 | rev_timestamp | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         1 | usertext_timestamp  |            1 | rev_user_text | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         1 | usertext_timestamp  |            2 | rev_timestamp | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         1 | page_user_timestamp |            1 | rev_page      | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         1 | page_user_timestamp |            2 | rev_user      | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
 * revision |         1 | page_user_timestamp |            3 | rev_timestamp | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |

関連項目

 * API:Database field and API property associations