• SQL Server定时执行SQL语句


    首先:

    定时作业的制定

    企业管理器

    --管理

    --SQL Server代理

    --右键作业

    --新建作业

    --"常规"项中输入作业名称

    --"步骤"项

    --新建

    --"步骤名"中输入步骤名

    --"类型"中选择"Transact-SQL 脚本(TSQL)"

    --"数据库"选择执行命令的数据库

    --"命令"中输入要执行的语句:

    EXEC 存储过程名 ... --该存储过程用于创建表

    --确定

    --"调度"项

    --新建调度

    --"名称"中输入调度名称

    --"调度类型"中选择你的作业执行安排

    --如果选择"反复出现"

    --点"更改"来设置你的时间安排

    然后将SQL Agent服务启动,并设置为自动启动,否则你的作业不会被执行

    设置方法:

    我的电脑--控制面板--管理工具--服务--右键 SQLSERVERAGENT--属性--启动类型--选择"自动启动"--确定.

    注意的是:

    1.在新建作业的属性中的分类选择“数据库维护”2.在调度中对于选择每天执行时,要选择每天执行的具体时间点,确保在指定的时间执行步骤的sql命令。

    SQL Server定时执行SQL语句

    存储过程

    set ANSI_NULLS ON
    set QUOTED_IDENTIFIER ON
    go


    ALTER PROCEDURE [dbo].[autoModify]
    as
    declare @Id int
    declare @Order_status int
    declare @FHTime datetime
    declare @Add_date datetime
    declare   pcurr    cursor   for
    select Id,Order_status,dateadd(day,10,FHTime) as FHTime,
    dateadd(day,14,Add_date) as Add_date from dbo.OrderInfo where Order_status=1 or Order_status=3
     open pcurr
      fetch next from pcurr into @Id,@Order_status,@FHTime,@Add_date
      while (@@fetch_status = 0)  
      begin  
      if(@Order_status=3)  
       begin
        if(@FHTime<getdate())
        begin
         --print 'a'
         update dbo.OrderInfo set Order_status=4 where [Id]=@Id
        end
       end
      else if(@Order_status=1)
       begin
        if(@Add_date<getdate())
        begin
         --print 'b'
         update dbo.OrderInfo set Order_status=0 where [Id]=@Id
        end
       end
     fetch next from pcurr into @Id,@Order_status,@FHTime,@Add_date 
     end  
     close pcurr  
     deallocate pcurr

    exec [autoModify]

  • 相关阅读:
    Arbitrage
    Big Event in HDU
    敌兵布阵
    Eddy's picture
    A Walk Through the Forest 最短路径+深搜
    Holding Bin-Laden Captive! 母函数
    Moving Tables 贪心
    Fire Net
    Number Sequence
    Find your present! map
  • 原文地址:https://www.cnblogs.com/ymyglhb/p/1734343.html
Copyright © 2020-2023  润新知