I’m working with a SQL Server 2000 database that likely has a few dozen tables that are no longer accessed. I’d like to clear out the data that we no longer need to be maintaining, but I’m not sure how to identify which tables to remove.
The database is shared by several different applications, so I can’t be 100% confident that reviewing these will give me a complete list of the objects that are used.
What I’d like to do, if it’s possible, is to get a list of tables that haven’t been accessed at all for some period of time. No reads, no writes. How should I approach this?
MSSQL2000 won’t give you that kind of information. But a way you can identify what tables ARE used (and then deduce which ones are not) is to use the SQL Profiler, to save all the queries that go to a certain database. Configure the profiler to record the results to a new table, and then check the queries saved there to find all the tables (and views, sps, etc) that are used by your applications.
Another way I think you might check if there’s any ‘writes’ is to add a new timestamp column to every table, and a trigger that updates that column every time there’s an update or an insert. But keep in mind that if your apps do queries of the type
then they will receive a new column and that might cause you some problems.