By nature, autoincrements go forward with every insert by the amount of the increment.
MS SQL Server offers a way to create a reverse order. Take a look here
create table #test
(
TestId INT IDENTITY (2, -1),
DateTimeStamp DateTime
)
GO
INSERT INTO #test (DateTimeStamp) Values (GETDATE());
INSERT INTO #test (DateTimeStamp) Values (GETDATE());
INSERT INTO #test (DateTimeStamp) Values (GETDATE());
INSERT INTO #test (DateTimeStamp) Values (GETDATE());
INSERT INTO #test (DateTimeStamp) Values (GETDATE());
INSERT INTO #test (DateTimeStamp) Values (GETDATE());
INSERT INTO #test (DateTimeStamp) Values (GETDATE());
INSERT INTO #test (DateTimeStamp) Values (GETDATE());
GO
SELECT * FROM #test
Results:
TestId DateTimeStamp
2 2009-07-28 15:02:09.200
1 2009-07-28 15:02:09.200
0 2009-07-28 15:02:09.200
-1 2009-07-28 15:02:09.200
-2 2009-07-28 15:02:09.203
-3 2009-07-28 15:02:09.203
-4 2009-07-28 15:02:09.203
-5 2009-07-28 15:02:09.207