Tracのテーブル

http://trac.edgewall.org/wiki/TracDev/DatabaseSchema

テーブル名 : ticket

チケットの基本情報が登録されるテーブルです。

カラム名Label解説
IDチケット番号チケットの管理ID。チケットごとに割り振られているユニークな番号です。
ticket_id_seqというシーケンスによって自動採番されます。
TYPEチケットの分類チケットに登録された分類名(※)
TIME登録日時チケット登録日時。Unixタイムスタンプで保管しています。
CHANGETIME最終変更日チケット最終更新日時。Unixタイムスタンプで保管しています。
COMPONENTコンポーネントチケットに登録されたコンポーネント名(※)
SERVERITY重要度チケットに登録された重要度(※)
PRIORITY優先度チケットに登録された優先度(※)
OWNER担当者チケットに登録されたそのチケットの担当者
REPORTER報告者チケットを登録した人
CC関係者チケットに登録されたチケットの関係者
VERSIONバージョンチケットに登録されたバージョン情報です。(※)
MILESTONEマイルストーンチケットに登録されたマイルストン(※)
STATUS状況チケットの現在の状況。
 new : 新規登録
 closed : 解決済み
 reopened : 一旦解決したチケットの着手再開
の何れかの値が入ります。
RESOLUTION解決方法チケットの解決方法。チケットのSTATUSが「closed」の場合のみセットされます。
 fixed : 解決(修正)
 invalid : 無効なチケット
 wontfix : 対応(修正)しないチケット
 duplicate : 重複しているチケット
 worksforme : 報告が再現しないチケット
の何れかの値が入ります。
SUMMARYチケットの概要チケットの概要
DESCRIPTIONチケットの説明チケットについての完全な説明。Wiki文章のフォーマットでそのまま格納されます。
KEYWORDSキーワードチケットに登録されたキーワード

テーブル名 : ticket_change

チケットの更新情報が登録されるテーブルです。
ticketテーブルの更新情報だけではなく、ticket_customの更新情報も登録されます。

カラム名解説
ticketチケットの管理ID。ticketテーブルのカラムIDと同じ要素です。
time変更日時。Unixタイムスタンプで保管しています。
author変更者
field変更箇所のカラム名。チケットが変更された際に該当する項目のカラム名が格納されます。
(tikcetテーブルもしくはticket_customのカラム名)
oldvalue変更前の値
newvalue変更後の値

テーブル名 : ticket_custom

追加したカスタムフィールドの値が登録されるテーブルです。

カラム名解説
ticketチケットの管理ID。ticketテーブルのカラムIDと同じ要素です。
nameカスタムフィールド名
valueカスタムフィールドの値

Trac本体の0.11から0.12へのバージョンアップに伴い、チケット関連のテーブルが仕様変更になっています。
具体的には登録日時と更新日時等(created, modified, date, time)の日時関連のカラムをミリ秒まで格納するようになりました。(参照:Microsecondtimestamps)
この影響でレポート中のSQLで日付のカラム(created, modified, date, time)をdateやstrftimeなどの日付関連の関数で変換している場合には、変換元の値を1000000で割らなければ日付関数での変換が出来なくなっています。

レポート表示の為の整形については後述する列名による表示整形で対処可能ですが、比較条件として日付を処理している場合には注意が必要です。

具体的にdate関数の場合には

0.11以前: date(time,'unixepoch','localtime')
0.12以降: date(time*1e-6,'unixepoch','localtime')

とする必要があります。

strftime関数の場合にはさらに注意が必要で、直接値を割るとレポートでエラーとなってしまうため、一旦date関数で変換後に再変換を行う必要があります。

0.11以前: strftime('%Y/%m/%d', time,'unixepoch''localtime') 
0.12以降: strftime('%Y/%m/%d', date(time*1e-6,'unixepoch','localtime'))

この仕様変更に伴い!Trac-0.12.1.ja1では、レポート機能での列名による表示整形を日本語対応しています。
列名による表示整形では列名の末尾が 時刻 で終わるカラムはtimeとして、 日付で終わるカラムは date として、 日時 で終わるカラムは datetime に、それぞれ整形されます。
列名を整形規則に合わせた場合には自動的に整形されるためSQLの関数での表示用の整形が不要になっています。
表示整形についての詳しい内容については、インストールしたTracに同梱のwiki TracReportsを参照してください。