I'm trying to create a job that will run based on the online status of a database. For example, step 1 will check if the database is online; if the database is online, it will run the rest of the steps, otherwise, it will report the job as successful.
Well you could set step 1 to be:
DECLARE @dbState TINYINT;
SELECT @dbState = state FROM sys.databases WHERE name = N'dbname';
IF @dbState = 0
BEGIN
RAISERROR('Database is online.', 11, 1);
END
Set the properties of step 1 to be:
Step 2 -> n-1 would do their normal things. Step n-1 might quit the job with success on success, or move to step N on success.
Step N could be as simple as:
PRINT 1;
...and would be set to quit the job with success.