powered by simpleCommunicator - 2.0.59     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Запустить package из T-SQL
6 сообщений из 6, страница 1 из 1
Запустить package из T-SQL
    #32022210
Александр
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Добрый день.

Как я могу запустить Local Package используя T-SQL ?
...
Рейтинг: 0 / 0
Запустить package из T-SQL
    #32022214
izvra
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
1.Добавте package на исполнение в SQL Server Agent
Посмотрите в на получившемся таске какая коматда выполняется

2.в процедуру надо вписать что-то наподобие этого

3.xp_cmdshell 'DTSRun /~Z0x0414A1F7B..............81E7A9DC0F6430CB396D65133E57674FBC94B9D7D5D58ACF4803D0BDBE79C1276B54B9AAAD56B58AD67574551EA0411EAAB6B23B0A35796FD21A59D639

4.стереть таск из SQL Server Agent


И дело в шляпе, если только с permissions всё впорядке.
...
Рейтинг: 0 / 0
Запустить package из T-SQL
    #32022220
AlexR
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
exec @hr = sp_OACreate 'DTS.Package', @oPKG OUT
exec @hr = sp_OAMethod @oPKG,'LoadFromStorageFile ("c:package.dts","")'--@LoadStr
exec @hr = sp_OAMethod @oPKG, 'Execute'
...
Рейтинг: 0 / 0
Запустить package из T-SQL
    #32022248
Владимир
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Создайте процедуру типа этой, чтобы было меньше рукопашной работы(зайди туда, создай удали и т.д)

SET NOCOUNT ON
begin
BEGIN TRANSACTION
declare @target varchar(12,@jb_name varchar(12,@err varchar(12
set @target=db_name()
set @jb_name='ChartingUpdate - '+@target
set @err='ChartingUpdate - '+@target

DECLARE @JobID BINARY(16)
DECLARE @ReturnCode INT
SELECT @ReturnCode = 0
IF (SELECT COUNT(*) FROM msdb.dbo.syscategories WHERE name = N'[Uncategorized (Local)]') < 1
EXECUTE msdb.dbo.sp_add_category @name = N'[Uncategorized (Local)]'

-- Delete the job with the same name (if it exists)
SELECT @JobID = job_id
FROM msdb.dbo.sysjobs
WHERE (name = @jb_name)
IF (@JobID IS NOT NULL)
BEGIN
-- Check if the job is a multi-server job
IF (EXISTS (SELECT *
FROM msdb.dbo.sysjobservers
WHERE (job_id = @JobID) AND (server_id <> 0)))
BEGIN
-- There is, so abort the script
RAISERROR (N'Unable to import job %s since there is already a multi-server job with this name.', 16, 1,@err)
GOTO QuitWithRollback
END
ELSE
-- Delete the [local] job
EXECUTE msdb.dbo.sp_delete_job @job_name = @jb_name---N'ChartingUpdate - '+@target SELECT @JobID = NULL
END

BEGIN

-- Add the job
EXECUTE @ReturnCode = msdb.dbo.sp_add_job @job_id = @JobID OUTPUT , @job_name = @jb_name, @owner_login_name = N'sa', @description = N'No description available.', @category_name = N'[Uncategorized (Local)]', @enabled = 1, @notify_level_email = 0, @notify_level_page = 0, @notify_level_netsend = 0, @notify_level_eventlog = 2, @delete_level= 0
IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

-- Add the job steps
EXECUTE @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID, @step_id = 1, @step_name = N'Auto update Proc', @command = N'AUTO_LineChartUpdate 2', @database_name = @target, @server = N'', @database_user_name = N'', @subsystem = N'TSQL', @cmdexec_success_code = 0, @flags = 0, @retry_attempts = 100, @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
EXECUTE @ReturnCode = msdb.dbo.sp_update_job @job_id = @JobID, @start_step_id = 1

IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

-- Add the job schedules
EXECUTE @ReturnCode = msdb.dbo.sp_add_jobschedule @job_id = @JobID, @name = N'database Start', @enabled = 1, @freq_type = 64
IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

-- Add the Target Servers
EXECUTE @ReturnCode = msdb.dbo.sp_add_jobserver @job_id = @JobID, @server_name = N'(local)'
IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

END
COMMIT TRANSACTION
GOTO EndSave
QuitWithRollback:
IF (@@TRANCOUNT > 0) ROLLBACK TRANSACTION
EndSave:
exec msdb.dbo.sp_start_job @job_name = @jb_name -- Старт задания...
end

Для запуска можно также стартануть из пакетника например:
osql -E -S %server% -d %database% -n -m-1 -r1 -Q "EXIT(execute job_chartingUpdate)"

Ну дальше карты в руки....
...
Рейтинг: 0 / 0
Запустить package из T-SQL
    #32022285
AlexR
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Зачем такие сложности. Чем не проще так как я написал.
Также пакет можна запустить на выполнение утилитой dtsrun, из TSQL ее можна запустить при помоши xp_cmdshell
...
Рейтинг: 0 / 0
Запустить package из T-SQL
    #32022310
Александр
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Всем большое спасибо !
...
Рейтинг: 0 / 0
6 сообщений из 6, страница 1 из 1
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Запустить package из T-SQL
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]