Skip to content

조회 수 18173 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
SQL Agent에 등록되어 있는 작업이 현재 실행중인지를 확인하는 프로시저입니다.
 
간단할꺼라 생각했는데, 쉽게 확인할 수 있는 사항이 아니었네요~
시스템 테이블과 저장 프로시저들을 참고하여 한 번 만들어봤습니다.
SQL 2000에서도 제대로 돌아가기 위해 결과테이블을 테이블 변수 대신 임시테이블로 정의하였습니다.
SQL 2005에서는 테이블 변수에다가 execute 결과를 저장할 수가 있지만, SQL 2000에서는 안되어서요~^^
참고하시기 바랍니다.
 
 

CREATE PROC USP_CHECK_JOB_STATUS

             @job_name sysname AS

SET NOCOUNT ON

 

DECLARE @is_sysadmin INT 

DECLARE @job_owner   sysname 

DECLARE @job_id uniqueidentifier

 

IF OBJECT_ID('TEMPDB..#job_execution_state') IS NOT NULL

DROP TABLE #job_execution_state

 

CREATE TABLE #job_execution_state

                           (

                                        job_id                UNIQUEIDENTIFIER NOT NULL, 

            last_run_date         INT              NOT NULL, 

            last_run_time         INT              NOT NULL, 

            next_run_date         INT              NOT NULL, 

            next_run_time         INT              NOT NULL, 

            next_run_schedule_id  INT              NOT NULL, 

            requested_to_run      INT              NOT NULL, -- BOOL 

            request_source        INT              NOT NULL, 

            request_source_id     sysname          COLLATE database_default NULL, 

            running               INT              NOT NULL, -- BOOL 

            current_step          INT              NOT NULL, 

            current_retry_attempt INT              NOT NULL, 

            job_state             INT              NOT NULL) 

 

SELECT @is_sysadmin = ISNULL(IS_SRVROLEMEMBER(N'sysadmin'), 0) 

SELECT @job_owner = SUSER_SNAME()

SELECT @job_id = job_id FROM msdb.dbo.sysjobs where name = @job_name

 

IF @job_id IS NOT NULL

             BEGIN

                           INSERT INTO #job_execution_state

                           EXEC master.dbo.xp_sqlagent_enum_jobs @is_sysadmin, @job_owner, @job_id

 

                           IF EXISTS (SELECT * FROM #job_execution_state)

                                        SELECT @job_name AS Name, running AS Status, CASE WHEN running = 1 THEN '실행중' ELSE '실행중이지 않음' END AS Comments

                                        FROM #job_execution_state

                           ELSE

                                        SELECT @job_name as Name, -1 as Status, '해당 작업이 없습니다.' AS Comments

             END

ELSE

             SELECT @job_name as Name, -1 as Status, '해당 작업이 없습니다.' AS Comments

 

SET NOCOUNT OFF

GO

 

 
 

USP_CHECK_JOB_STATUS 'TEST'

/*

Name     Status      Comments

-------- ----------- --------

TEST     1           실행중

*/

 

USP_CHECK_JOB_STATUS 'TEST'

/*

Name     Status      Comments

-------- ----------- --------

TEST     0           실행중이지 않음

*/

 

USP_CHECK_JOB_STATUS 'TEST1'

/*

Name     Status      Comments

-------- ----------- --------

TEST1     -1         해당 작업이 없습니다.

*/


  1. DB 서버에 특정 IP 접근 차단 방법

  2. No Image 29May
    by l2zeo
    2010/05/29 by l2zeo
    Views 21801 

    DBCC SHRINKFILE 트랜잭션 로그파일 축소

  3. No Image 03Jun
    by ADMINPLAY
    2010/06/03 by ADMINPLAY
    Views 23017 

    Fatal error: Call to undefined function: mssql_connect()

  4. No Image 13Apr
    by ADMINPLAY
    2009/04/13 by ADMINPLAY
    Views 7495 

    Firehose 모드에서는 트랜젝션을 시작할수 없습니다

  5. No Image 20Sep
    by ADMINPLAY
    2014/09/20 by ADMINPLAY
    Views 4977 

    MicroSoft SQL Server 2008 1433 port 원격(외부)접속 허용하기

  6. No Image 26Nov
    by ADMINPLAY
    2009/11/26 by ADMINPLAY
    Views 9852 

    Ms-Sql 백업 format옵션

  7. No Image 26Nov
    by ADMINPLAY
    2009/11/26 by ADMINPLAY
    Views 16256 

    MS-SQL 클라이언트 설치 방법

  8. No Image 26Nov
    by ADMINPLAY
    2009/11/26 by ADMINPLAY
    Views 16337 

    MSSQL 2005 접속 클라이언트(mssql server management Studio Express)

  9. No Image 24Feb
    by l2zeo
    2010/02/24 by l2zeo
    Views 23866 

    MSSQL 버전별 최대 용량 비교표

  10. No Image 26Nov
    by ADMINPLAY
    2009/11/26 by ADMINPLAY
    Views 9165 

    MSSQL 접속 방법

  11. No Image 19Nov
    by ADMINPLAY
    2009/11/19 by ADMINPLAY
    Views 9665 

    MSSQL 클러스터

  12. No Image 15May
    by ADMINPLAY
    2009/05/15 by ADMINPLAY
    Views 11522 

    MSSQL 트랜잭션로그삭제

  13. No Image 10Nov
    by ADMINPLAY
    2009/11/10 by ADMINPLAY
    Views 7521 

    MSSQL 파일사이즈 줄이기

  14. No Image 04Jun
    by ADMINPLAY
    2009/06/04 by ADMINPLAY
    Views 10426 

    mssql2005 원격접속 허용 - 노출 영역 구성

  15. No Image 26Nov
    by ADMINPLAY
    2009/11/26 by ADMINPLAY
    Views 9325 

    MsSQL에서 소유자(mssql2000 => mssql2005으로 복원)

  16. No Image 14Dec
    by ADMIN
    2008/12/14 by ADMIN
    Views 8789 

    mysql 대량 쿼리 보내기

  17. No Image 13Apr
    by ADMINPLAY
    2009/04/13 by ADMINPLAY
    Views 16785 

    php에서 mssql 연동방법(총정리)

  18. sa계정 패스워드변경하기

  19. No Image 16Jan
    by ADMINPLAY
    2012/01/16 by ADMINPLAY
    Views 14558 

    SET LOCK_TIMEOUT

  20. No Image 23Feb
    by l2zeo
    2010/02/23 by l2zeo
    Views 18173 

    SQL Agent 작업 실행 상태 확인하기

Board Pagination Prev 1 2 Next
/ 2

Copyright ADMINPLAY corp. All rights reserved.

abcXYZ, 세종대왕,1234

abcXYZ, 세종대왕,1234