Request Tracker (also know as RT), the defacto Open Source ticket tracking software, has a special status value to get rid of spam tickets: deleted. It does exactly what it's supposed to do, that is get rid of these tickets quickly.
Unfortunately, it's very easy to accidentally delete a bunch of non-spam tickets via the bulk update interface. Restoring these deleted tickets is not straightforward.
Good news: none of the lost tickets were removed from the database.
Bad news: you can't search for deleted tickets.
Finding the lost tickets
If you have a copy of the page before you did the bulk update (perhaps in your browser cache?) then you've got all you need. Otherwise, you'll need to access the database directly to get a list of ticket IDs.
First of all, find the user ID of the person who marked of all these tickets as deleted (42 in this example), then issue the following query:
SELECT id, lastupdated, subject FROM tickets WHERE status = 'deleted' AND lastupdatedby = 42 ORDER BY lastupdated;
You may want to filter some more using the lastupdated
timestamp if you know roughly when the deletion occurred.
Restoring deleted tickets
Since all of the tickets are still in the database, all you need to do is to go to each of them directly (e.g. http://www.example.com/Ticket/Display.html?id=12345
for Ticket #12345) and change the status back to "open".
If you have the tickets in a query (ie. the WHERE clause) can't you just use that where clause in an UPDATE to set the status back.
I presume doing it via the interface does some other housekeeping like changing the lastupdated?