WordPress.org

Ready to get started?Download WordPress

Codex

ko:한국어

Contents

아래 내용은 WordPress Version 3.4를 표준 설치하는동안 생성되는 database 테이블에 대한 개요와 설명이다. 현재, 워드프레스에서 데이터베이스는 MySQL 버전 5.0.15 혹은 그 이상만을 지원한다.

또한 이전 버전의 데이터베이스 설명은 다음을 참고하면 된다 : WordPress 1.5, WordPress 2.0, WordPress 2.2, WordPress 2.3, WordPress 2.5, WordPress 2.7, WordPress 2.8, WordPress 2.9, WordPress 3.3.

워드프레스는 이 데이터베이스와 자동으로 통신하므로, 말단 사용자들은 데이터베이스 구조에 대해 알 필요가 없다. 하지만, 플러그인 작성자(Writing a Plugin)의 경우 워드프레스가 어떻게 데이터를 저장하고 그들간의 관계에 대해 어떻게 정의하는지 궁금해 할 것이다. 만약 이 글을 읽고 있는 당신이 WordPress API를 이용하여 워드프레스 데이터에 접근해보았으나 데이터베이스에 직접적으로 접근할 수 없었다면, 워드프레스에서 제공하는 wpdb를 참조하면 된다. 손쉽게 데이터베이스에 직접 접근을 할 수 있을 것이다.

데이터베이스 다이어그램

아래 다이어그램은 워드프레스 테이블 간의 관계와 데이터베이스를 시각적으로 보여준다. 워드프레스의 데이터베이스는 표준 설치시 자동으로 생성된다. 다이어그램 아래의 테이블 개요는 테이블과 컬럼들에 대한 추가적인 상세 내용을 포함하고 있다.

(WP 3.0 Database diagram)

워드프레스 표준 설치시 테이블들(포스트들과 코멘트들간)간의 무결성 제약조건을 제공하지 않는다. 당신이 워드프레스 데이터베이스를 조작하는 플러그인이나 추가 기능을 만들고 있다면, 데이터간 관계를 잃어 고아가 되는 레코드가 남지 않도록 신경써서 코드를 작성해야 한다.

테이블 개요

이 섹션은 워드프레스 표준 설치시 생성되는 모든 테이블에 대한 개요를 설명한다. 각 테이블에서 특정정보가 무엇인지도 설명한다.


워드프레스 3.4 테이블 (11)
테이블 명 설명 연관된 사용자 인터페이스
wp_commentmeta 각각의 코멘트에 대한 메타데이터를 저장하는 테이블.
wp_comments 코멘트를 저장하는 테이블.
wp_links 링크와 연관된 정보를 저장하는 테이블. 워드프레스의 Links에서 입력되는 링크이다.
wp_options Administration > Settings 패널에서 설정된 Options들이 저장되는 테이블. 참조 : Option Reference - 옵션 이름들과 기본값 설명이 되어있다.
wp_postmeta 각 포스트에 연관된 메타데이터를 저장하는 테이블. 플러그인 작성시 이 테이블에 원하는 정보를 추가(임의의 메타데이터 이름 생성 가능)할 수도 있다.
wp_posts 워드프레스 데이터의 가장 중요한 부분인 포스트가 저장되는 테이블. 페이지와 내비게이션 메뉴 아이템들도 이 테이블에 저장된다.
wp_terms 포스트와 링크의 카테고리, 포스트에 대한 태그가 저장되는 테이블.
wp_term_relationships 포스트들은 카테고리들과 태그들(카테고리와 태그는 wp_terms에 저장됨.)에 의해 연관 지어진다. 이 관계를 지어주는 관계테이블이 wp_term_relationships이다. 또한, 링크들이 각각의 카테고리와 연관 지어지는 관계도 이 테이블에 저장된다.
wp_term_taxonomy 이 테이블은 wp_terms 테이블에 저장된 엔트리들에 대해서 category, link, tag와 같은 분류 이름을 저장하는 테이블이다.
wp_usermeta 사용자에 대한 메타데이터를 저장하는 테이블.
wp_users 사용자에 대한 정보를 저장하는 테이블.

테이블 상세

다음은 워드프레스 표준설치시 생성되는 테이블의 각각의 필드들에 대한 상세 설명이다.

Table: wp_commentmeta

FieldTypeNullKeyDefaultExtra
meta_idbigint(20) unsigned PRINULLauto_increment
comment_idbigint(20) unsigned IND0FK->wp_comments.comment_id
meta_keyvarchar(255)YESINDNULL 
meta_valuelongtextYES NULL 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY0meta_ID
comment_idINDEXnonecomment_id
meta_keyINDEXnonemeta_key

Table: wp_comments

FieldTypeNullKeyDefaultExtra
comment_IDbigint(20) unsigned PRINULLauto_increment
comment_post_IDbigint(20) unsigned IND0FK->wp_posts.ID
comment_authortinytext    
comment_author_emailvarchar(100)    
comment_author_urlvarchar(200)    
comment_author_IPvarchar(100)    
comment_datedatetime  0000-00-00 00:00:00 
comment_date_gmtdatetime IND & IND Pt20000-00-00 00:00:00 
comment_contenttext    
comment_karmaint(11)  0 
comment_approvedvarchar(20) IND & Ind Pt11 
comment_agentvarchar(255)    
comment_typevarchar(20)    
comment_parentbigint(20) unsigned  0FK->wp_comments.ID
user_idbigint(20) unsigned  0FK->wp_users.ID

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY1comment_ID
comment_post_IDINDEXNonecomment_post_ID
comment_approved_date_gmtINDEXNonecomment_approved
comment_date_gmt
comment_date_gmtINDEXNonecomment_date_gmt
comment_parentINDEXNonecomment_parent

Table: wp_links

FieldTypeNullKeyDefaultExtra
link_idbigint(20) unsigned PRINULLauto_increment
link_urlvarchar(255)    
link_namevarchar(255)    
link_imagevarchar(255)    
link_targetvarchar(25)    
link_descriptionvarchar(255)    
link_visiblevarchar(20) INDY 
link_ownerbigint(20) unsigned  1 
link_ratingint(11)  0 
link_updateddatetime  0000-00-00 00:00:00 
link_relvarchar(255)    
link_notesmediumtext    
link_rssvarchar(255)    

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY7link_ID
link_categoryINDEXNonelink_category
link_visibleINDEXNonelink_visible

Table: wp_options

FieldTypeNullKeyDefaultExtra
option_idbigint(20) unsigned PRI Pt1NULLauto_increment
option_namevarchar(64) PRI Pt3 & IND  
option_valuelongtext   
autoloadvarchar(20)  yes 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY184option_id
blog_id
option_name
option_nameUNIQUE184option_name

Table: wp_postmeta

FieldTypeNullKeyDefaultExtra
meta_idbigint(20) unsigned PRINULLauto_increment
post_idbigint(20) unsigned IND0FK->wp_posts.ID
meta_keyvarchar(255)YESINDNULL 
meta_valuelongtextYES NULL 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY13meta_ID
post_idINDEX15post_id
meta_keyINDEX7meta_key

Table: wp_posts

FieldTypeNullKeyDefaultExtra
IDbigint(20) unsigned PRI & IND Pt4 auto_increment
post_authorbigint(20) unsigned  0FK->wp_users.ID
post_datedatetime IND Pt30000-00-00 00:00:00 
post_date_gmtdatetime  0000-00-00 00:00:00 
post_contentlongtext    
post_titletext    
post_excerpttext    
post_statusvarchar(20) IND PT2publish 
comment_statusvarchar(20)  open 
ping_statusvarchar(20)  open 
post_passwordvarchar(20)    
post_namevarchar(200) IND  
to_pingtext    
pingedtext    
post_modifieddatetime  0000-00-00 00:00:00 
post_modified_gmtdatetime  0000-00-00 00:00:00 
post_content_filteredlongtext   
post_parentbigint(20) unsigned  0FK->wp_posts.ID
guidvarchar(255)    
menu_orderint(11)  0 
post_typevarchar(20) IND Pt1post 
post_mime_typevarchar(100)    
comment_countbigint(20)  0 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY2ID
post_nameINDEXNonepost_name
type_status_dateINDEXNonepost_type
post_status
post_date
ID
post_parentINDEXNonepost_parent
post_authorINDEXNonepost_author

Table: wp_terms

FieldTypeNullKeyDefaultExtra
term_idbigint(20) unsigned PRI auto_increment
namevarchar(200)     
slugvarchar(200) UNI  
term_groupbigint(10)  0 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY2term_ID
slugUNIQUE2slug
nameIndexnonename

Table: wp_term_relationships

FieldTypeNullKeyDefaultExtra
object_idbigint(20) unsigned PRI Pt10 
term_taxonomy_idbigint(20) unsigned PRI Pt2 & IND0FK->wp_term_taxonomy.term_taxonomy_id
term_orderint(11)  0 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY8object_id
term_taxonomy_id
term_taxonomy_idINDEXNoneterm_taxonomy_id

Table: wp_term_taxonomy

FieldTypeNullKeyDefaultExtra
term_taxonomy_idbigint(20) unsigned PRI auto_increment
term_idbigint(20) unsigned UNI Pt10 FK->wp_terms.term_id
taxonomyvarchar(32) UNI Pt2  
descriptionlongtext    
parentbigint(20) unsigned  0 
countbigint(20)  0 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY2term_taxonomy_id
term_id_taxonomyUNIQUE2term_id
taxonomy
taxonomyINDEXNonetaxonomy

Table: wp_usermeta

FieldTypeNullKeyDefaultExtra
umeta_idbigint(20) unsigned PRINULLauto_increment
user_idbigint(20) unsigned  '0'FK->wp_users.ID
meta_keyvarchar(255)YesINDNULL 
meta_valuelongtextYesINDNULL 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY9umeta_id
user_idINDEXNoneuser_id
meta_keyINDEXNonemeta_key

Table: wp_users

FieldTypeNullKeyDefaultExtra
IDbigint(20) unsigned PRINULLauto_increment
user_loginvarchar(60) IND  
user_passvarchar(64)    
user_nicenamevarchar(50) IND  
user_emailvarchar(100)    
user_urlvarchar(100)    
user_registereddatetime  0000-00-00 00:00:00 
user_activation_keyvarchar(60)   
user_statusint(11)  0 
display_namevarchar(250)     

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY1ID
user_login_keyINDEXNoneuser_login
user_nicenameINDEXNoneuser_nicename

Multisite Table Overview

This section is the overview of the tables created for use with the Multisite feature of WordPress. These tables are created via the processes under Administration > Tools > Network.

These tables are considered the multisite global tables.

WordPress 3.0 Multisite Tables
Table Name Description Relevant Area(s) of WordPress User Interface
wp_blogs Each site created is stored in the table, wp_blogs.
wp_blog_versions The current database version status of each site is maintained in the wp_blogs_versions table and is updated as each site is upgraded.
wp_registration_log The wp_registration_log records the admin user created when each new site is created.
wp_signups This table holds the user that have registered for a site via the login registration process. User registration is enable in Administration > Super Admin > Options.
wp_site The wp_site table contains the main site address.
wp_sitecategories If global terms (global_terms_enabled = true) are enabled for a site the wp_sitecategories table holds those terms.
wp_sitemeta Each site features information called the site data and it is stored in wp_sitemeta. Various option information, including the site admin is kept in this table.
wp_users The list of all users is maintained in table wp_users. Multisite add two fields not in the stand-alone version.
wp_usermeta This table is not re-create for multisite, but meta data of users for each site are stored in wp_usermeta.
Site Specific Tables The data of the main site are stored in existing unnumbered tables. The data of additional sites are stored in new numbered tables.


Multisite Table Details

The following describe the tables and fields created during the network installation. Note that a global set of tables is created upon creation of the network, and site-specific tables are established as each site is created.

Table: wp_blogs

FieldTypeNullKeyDefaultExtra
blog_idbigint(20) unsigned PRINULLauto_increment
site_idbigint(20) unsigned IND0
domainvarchar(200)NO 0 
pathvarchar(100)NO   
registereddatetimeNO 0000-00-00 00:00:00 
last_updateddatetimeNO 0000-00-00 00:00:00 
publictinyint(2)NO 0 
archivedenum('0','1')NO 0 
maturetinyint(2)NO 0 
spamtinyint(2)NO 0 
deletedtinyint(2)NO 0 
lang_idint(11)NO 0 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY2blog_id
domainINDEXnonedomain(50),path(5)
lang_idINDEXnonelang_id

Table: wp_blog_versions

FieldTypeNullKeyDefaultExtra
blog_idbigint(20) unsigned PRI0FK->wp_blogs.blog_id
db_versionvarchar(20)NO   
last_updateddatetimeNO 0000-00-00 00:00:00 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY2blog_id
db_versionINDEXnonedb_version

Table: wp_registration_log

FieldTypeNullKeyDefaultExtra
IDbigint(20) unsigned PRINULLauto_increment
emailvarchar(255)NO   
IPvarchar(30)NO   
blog_idbigint(20) unsigned PRI0FK->wp_blogs.blog_id
date_registereddatetimeNO 0000-00-00 00:00:00 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY1ID
IPINDEXnoneIP

Table: wp_signups

FieldTypeNullKeyDefaultExtra
domainvarchar(200)NO 0 
pathvarchar(100)NO   
titlelongtextNO   
user_loginvarchar(60)NOIND  
user_emailvarchar(100)NO   
registereddatetimeNO 0000-00-00 00:00:00 
activateddatetimeNO 0000-00-00 00:00:00 
activetinyint(1)NO  
activation_keyvarchar(50)NO   
metalongtext     

Indexes

KeynameTypeCardinality Field
activation_keyINDEXNoneactivation_key
domainINDEXNonedomain

Table: wp_site

FieldTypeNullKeyDefaultExtra
idbigint(20) unsigned PRINULLauto_increment
domainvarchar(200)NO 0 
pathvarchar(100)NO   

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY1id
domainINDEXnonedomain,path

Table: wp_sitecategories

FieldTypeNullKeyDefaultExtra
cat_idbigint(20) unsignedNOPRINULLauto_increment
cat_namevarchar(55)NO   
category_nicenamevarchar(200)NO   
last_updatedtimestampNO   

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY9cat_id
category_nicenameINDEXNonecategory_nicename
last_updatedINDEXNonelast_updated

Table: wp_sitemeta

FieldTypeNullKeyDefaultExtra
meta_idbigint(20) unsigned PRINULLauto_increment
site_idbigint(20) unsigned  '0'FK->wp_site.site_id
meta_keyvarchar(255)YesINDNULL 
meta_valuelongtextYesINDNULL 

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY9meta_id
meta_keyINDEXNonemeta_key
site_idINDEXNonesite_id

Table: wp_users

FieldTypeNullKeyDefaultExtra
IDbigint(20) unsigned PRINULLauto_increment
user_loginvarchar(60) IND  
user_passvarchar(64)    
user_nicenamevarchar(50) IND  
user_emailvarchar(100)    
user_urlvarchar(100)    
user_registereddatetime  0000-00-00 00:00:00 
user_activation_keyvarchar(60)   
user_statusint(11)  0 
display_namevarchar(250)     
spamtinyint(2)NO  0
deletedtinyint(2)NO  0

Indexes

KeynameTypeCardinality Field
PRIMARYPRIMARY1ID
user_login_keyINDEXNoneuser_login
user_nicenameINDEXNoneuser_nicename

Site Specific Tables

When a new additional site is created, the site-specific tables, similar to the stand-alone tables above, are created. Each set of tables for a site are created with the site ID (blog_id) as part of the table name. These are the tables that would be created for site ID 2 and table_prefix wp_:

The data of the main site are stored in unnumbered tables.

Resources

Changelog

  • 2.8 :
    • comments table: Changed comment_post_ID column from int(11) to bigint(20) unsigned.
    • links table: Deleted link_category column. Changed link_owner column from int(11) to bigint(20) unsigned.
    • posts table: Deleted post_category column.
    • term_taxonomy table: Added KEY taxonomy.
    • Add unsigned attribute to various bigint(20) fields.