U slučajevima kada nemamo Enterprise manager, kako bismo kreirali job na SQL
serveru, možemo to isto napraviti upotrebom T-SQL naredbi.
Job će napraviti kompletni preračun. Ako to ne želite, onda popravite naredbe
u koracima (steps).
Za pravilno djelovanje je potrebno u skripti popraviti:
- servername = SERVER (ime servera, na kojem izvršavamo
job, odnosno na njemu je baza podataka)
- databasename = msDataLab (ime baze podataka, za koju
radimo preračun prometa)
Upisane vrijednosti (italic i bold) je potrebno promijeniti s imenom vašeg
servera i vaše baze podataka, a to možete najlakše popraviti s find/replace
funkcijom pri upisivanju skripte.
Programski kod za skriptu, koji nam kreira takav job je niže naveden:
begin transaction
declare
@JobID binary(16),
@ReturnCode int
set nocount on
select @ReturnCode = 0
-- kreiraj glavu joba
execute @ReturnCode = msdb.dbo.sp_add_job @job_id = @JobID output,
@job_name = N'Preračun prometov - vsak 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 - Preračunaj serijske
execute @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID,
@step_id = 1, @step_name = N'Preračunaj serijske',
@command = 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_success_code = 0, @flags = 0, @retry_attempts = 0,
@retry_interval = 1, @output_file_name = N'', @on_success_step_id = 0,
@on_success_action = 3, @on_fail_step_id = 0, @on_fail_action = 2
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
-- kreiraj step 2 - Preračunaj cijene
execute @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID,
@step_id = 2, @step_name = N'Preračunaj cene',
@command = 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_success_code = 0, @flags = 0, @retry_attempts = 0,
@retry_interval = 1, @output_file_name = N'', @on_success_step_id = 0,
@on_success_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 zalogo',
@command = N'exec dl_PA_ObrProm_ObnovitevZaloge ''''',
@database_name = N'msDataLab', @server = N'',
@database_user_name = N'', @subsystem = N'TSQL',
@cmdexec_success_code = 0, @flags = 0, @retry_attempts = 0,
@retry_interval = 1, @output_file_name = N'', @on_success_step_id = 0,
@on_success_action = 3, @on_fail_step_id = 0, @on_fail_action = 2
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
-- kreiraj step 4 - Preračunaj glave dokumenata
execute @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID,
@step_id = 4, @step_name = N'Preračunaj glave dokumenata',
@command = 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_PreracunNarocOdprem '''', null, null
exec dl_PA_ObrProm_PreracunPromet null, null, ''F''',
@database_name = N'msDataLab', @server = N'',
@database_user_name = N'', @subsystem = N'TSQL',
@cmdexec_success_code = 0, @flags = 0, @retry_attempts = 0,
@retry_interval = 1, @output_file_name = N'', @on_success_step_id = 0,
@on_success_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'Vsakodnevno izvajanje ob 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_recurrence_factor = 1,
@active_end_date = 99991231, @active_end_time = 235959
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
-- postavi job u izvođenje na poslužitelj
execute @ReturnCode = msdb.dbo.sp_add_jobserver @job_id = @JobID,
@server_name = N'POSLUŽITELJ', @automatic_post = 0
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
select @JobID
if (@@ERROR <> 0 OR @ReturnCode <> 0)
goto QuitWithRollback
commit transaction
goto EndSave
QuitWithRollback:
IF (@@TRANCOUNT > 0) rollback transaction
EndSave:
I kod ove skripte vrijede sve napomene, koje smo zapisali u kreiranju
preračuna prometa s Enterprise manager-om.