Attachments in the SpiraTeam Database
When you upload a new attachment into SpiraTeam, it creates two entries in the database, TST_ATTACHMENT and TST_ATTACHMENT_VERSION. We will examine each of these in turn.
TST_ATTACHMENT
This table contains a row for each attachment, including the filename and mime type:
data:image/s3,"s3://crabby-images/c727e/c727e0a5445fa9e556a574746a8d9491a48cb45b" alt=""
If you decide to upload a new version of the same attachment, the version number gets updated, but the primary key (ATTACHMENT_ID) does not change. The FILENAME field contains the actual filename of the attachment and the extension will be correct filetype (e.g. .pdf, .xlsx, etc.)
TST_ATTACHMENT_VERSION
This table contains a row for each version of each attachment:
data:image/s3,"s3://crabby-images/f43b7/f43b7f11e654e762c36111f786c71febd263676e" alt=""
If you upload a new version of an existing document, the new row will have the same ATTACHMENT_ID (linked back to the TST_ATTACHMENT table), but a new ATTACHMENT_VERSION_ID.
Attachments in the Web Server Repository
On the web server running SpiraTeam, you will see a set of .dat files on the file system:
data:image/s3,"s3://crabby-images/14ca1/14ca1e6ed05a6b0fc37ecb756561f9971b56f760" alt=""
These files correspond to the ATTACHMENT_VERSION_ID (in very early versions of SpiraTeam it used to be the ATTACHMENT_ID). So if you know the ATTACHMENT_VERSION_ID then you simply need that ID's file:
<ATTACHMENT_ID>.dat