U slučajevima, kada nemamo Enterprise manager, da bi kreirali job na SQL
serveru, možemo to isto da uradimo korišćenjem T-SQL naredbe.
Job će napraviti kompletni proračun. Ako to ne želite, onda popravite ukaze u
koracima (steps).
Za pravilno delovanje je potrebno u skriptu popraviti:
- servername = SERVER
(ime servera, na kojem radimo job od. na njemu je baza podataka)
- databasename = msDataLab (ime baze podataka, za koju
radimo proračun prometa)
Upisane vrednosti (italic i bold) je potrebno promeniti sa imenom vašeg
servera i vaše baze podataka, to najlakše popravite s find/replace
funkcijom pri upisivanju skripta.
Programski kod za skript, koji nam kreira takav job je naveden ispod:
begin transaction
declare
@JobID binary(16),
@ReturnCode int
set nocount on
select @ReturnCode = 0
-- kreiraj glavo joba
execute @ReturnCode = msdb.dbo.sp_add_job @job_id = @JobID output,
@job_name = N'Proračun prometa - svaki dan', @enabled = 1,
@description = N'',
@category_name = N'[Uncategorized (Local)]',
@notify_level_eventlog = 2, @delete_level= 0
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
-- kreiraj step 1 - Proračun serijske
execute @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID,
@step_id = 1, @step_name = N'Proračunaj serijske',
@comimand = N'exec dl_PA_ObrProm_StetjeSerialNo '''', null, null
exec dl_PA_ObrProm_StatusSerialNo ''''', @database_name = N'msDataLab',
@server = N'', @database_user_name = N'', @subsystem = N'TSQL',
@cmdexec_succijess_code = 0, @flags = 0, @retry_attempts = 0,
@retry_interval = 1, @output_file_name = N'', @on_succijess_step_id = 0,
@on_succijess_action = 3, @on_fail_step_id = 0, @on_fail_action = 2
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
-- kreiraj step 2 - Proračun cene
execute @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID,
@step_id = 2, @step_name = N'Proračunaj cene',
@comimand = N'exec dl_PA_ObrProm_CalcCen '''', null, null, ''''
exec dl_PA_ObrProm_CalcLastCen '''', null, null, ''''
exec dl_PA_ObrProm_PreracunNabCenZbirno ''''',
@database_name = N'msDataLab', @server = N'',
@database_user_name = N'',@subsystem = N'TSQL',
@cmdexec_succijess_code = 0, @flags = 0, @retry_attempts = 0,
@retry_interval = 1, @output_file_name = N'', @on_succijess_step_id = 0,
@on_succijess_action = 3, @on_fail_step_id = 0, @on_fail_action = 2
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
-- kreiraj step 3 - Obnovi zalihu
execute @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID,
@step_id = 3, @step_name = N'Obnovi zalihu',
@comimand = N'exec dl_PA_ObrProm_ObnovuZalihe ''''',
@database_name = N'msDataLab', @server = N'',
@database_user_name = N'', @subsystem = N'TSQL',
@cmdexec_succijess_code = 0, @flags = 0, @retry_attempts = 0,
@retry_interval = 1, @output_file_name = N'', @on_succijess_step_id = 0,
@on_succijess_action = 3, @on_fail_step_id = 0, @on_fail_action = 2
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
-- kreiraj step 4 - Proračun glave dokumenata
execute @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID,
@step_id = 4, @step_name = N'Proračunaj glave dokumenata',
@comimand = N'exec dl_PA_ObrProm_PreracunBlagajna null, null
exec dl_PA_ObrProm_PreracunDenar null, null
exec dl_PA_ObrProm_PreracunNaroc null, null
exec dl_PA_ObrProm_PreracunNarocOtvorim '''', null, null
exec dl_PA_ObrProm_PreracunPromet null, null, ''F''',
@database_name = N'msDataLab', @server = N'',
@database_user_name = N'', @subsystem = N'TSQL',
@cmdexec_succijess_code = 0, @flags = 0, @retry_attempts = 0,
@retry_interval = 1, @output_file_name = N'', @on_succijess_step_id = 0,
@on_succijess_action = 1, @on_fail_step_id = 0, @on_fail_action = 2
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
-- zapiši početni korak u job
execute @ReturnCode = msdb.dbo.sp_update_job @job_id = @JobID, @start_step_id = 1
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
-- postavi schedule izvođenja
execute @ReturnCode = msdb.dbo.sp_add_jobschedule @job_id = @JobID,
@name = N'Svakodnevno izvođenje pri 01.00', @enabled = 1,
@freq_type = 4, @active_start_date = 20020103,
@active_start_time = 10000, @freq_interval = 1,
@freq_subday_type = 1, @freq_subday_interval = 0,
@freq_relative_interval = 0, @freq_recurrencije_factor = 1,
@active_end_date = 99991231, @active_end_time = 235959
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
-- daj job u izvođenje na server
execute @ReturnCode = msdb.dbo.sp_add_jobserver @job_id = @JobID,
@server_name = N'SERVER', @automatic_post = 0
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
select @JobID
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
comimit transaction
goto EndSave
QuitWithRollback:
IF (@@TRANCOUNT > 0) rollback transaction
EndSave:
I kod ovog skripta važe sve napomene, koje smo zapisali u kreiranju
proračuna prometa sa Enterprise Manager-om.