I have a forum on my site and want to add the feature that each user can see which threads they have viewed and which they haven't.

What is the best way of doing this? Is the only way to have a list of which threads every single user has viewed in a database. Surely in a message board like this table will be massive, especially as every thread is archived or is there someway of checking the cache and dates?