SQL Server 定时作业

SQL Server:定时作业的设置方法
--------------------------------------------------------------------------------

如果在SQL Server 里需要定时或者每隔一段时间执行某个存储过程或3200字符以内的SQL语句时,可以用管理->SQL Server代理->作业来实现。

1、管理->SQL Server代理->作业(按鼠标右键)->新建作业

2、新建作业属性(常规)->名称[自定义本次作业的名称]->启用的方框内是勾号->分类处可选择也可用默认的[未分类(本地)]->所有者默认为登录SQL Server用户[也可选其它的登录]->描述[填写本次工作详细描述内容];

创建作业分类的步骤: SQL Server代理->作业->右键选所有任务->添加、修改、删除

3、新建作业属性(步骤)->新建->步骤名[自定义第一步骤名称]->类型[Transact-SQL(TSQL)脚本]->数据库[要操作的数据库]->命令 [ 如果是简单的SQL直接写进去即可,也可用打开按钮输入一个已写好的*.sql。文件如果要执行存储过程,填 exec p_procedure_name v_parameter1,[ v_parameter2…v_parameterN] ->确定 (如果有多个步骤,可以再次调用下面的新建按钮;也可以对已有的多个步骤插入、编辑、删除);

4、建作业属性(调度)->新建调度->名称[自定义调度名称]->启用的方框内是勾号->调度->反复出现-> 更改[调度时间表]->确定(如果只要保存此作业,不要定时做可以把启用的方框内是勾号去掉);

5、建作业属性(通知)->用默认的通知方法就好[当作业失败时,写入Windows应用程序系统日志] ->确定。

跟作业执行相关的一些SQL Server知识:

SQL Server Agent服务必须正常运行,启动它的NT登录用户要跟启动SQL Server数据库的NT登录用户一致;

点作业右键可以查看作业执行的历史记录情况,也可以立即启动作业和停止作业。

最近在看作业历史记录时,发现有的作业记录的历史记录多,有的作业记录的记录的历史记录少。如何能使某些作业按各自的需求,保留一段时间.比如保留一个月的历史记录.看了SQL Server的在线帮助文档,里面介绍说:

在管理->SQL Server代理->右键选属性->作业系统->限制作业历史记录日志的大小

作业历史记录日志的最大大小(行数) ,默认为1000 。如果某台机器的作业数量很多,一定要提高它,例如为100000

每个作业历史记录日志的最大行数,默认为100。如果作业每天执行两次,需要保留一个月的日志,可以设为60

它们之间有一个相互制约关系, 我们可以根据自己的需要来改.

如果SQL Server服务器改过机器名, 管理是旧名称时建立的job的时候可能会遇到。错误14274: 无法添加、更新或删除从MSX服务器上发起的作业(或其步骤或调度)。看了Microsoft的文档:http://support.microsoft.com/default.aspx?scid=kb;en-us;281642说SQL Server 2000系统里msdb..sysjobs 里originating_server 字段里存的是原来的服务器的名称。24X7在用的系统肯定不能按上面Microsoft的文档说的那样把名字改回来又改过去。于是想,msdb..sysjobs 能否update originating_server 字段成现在在用的新服务器名?

use msdb
select * from sysjobs


找到originating_server 字段还是旧服务器的job_id, 然后执行update语句:

update sysjobs set originating_server='new_server_name'
where job_id='B23BBEBE-A3C1-4874-A4AB-0E2B7CD01E14'


(所影响的行数为 1 行)

这样就可以添加、更新或删除那些曾经出error 14274 的作业了。

如果想把作业由一台机器迁移到另一台机器,可以先保留好创建作业的脚本, 然后在另一台机器上运行。

导出所有作业的创建脚本操作步骤:

管理->SQL Server代理->作业(鼠标右键)->所有任务->生成SQL脚本->保存到操作系统下的某个sql文件

导出某一个作业的创建脚本操作步骤:

管理->SQL Server代理->作业->选中待转移的作业(鼠标右键)->所有任务->生成SQL脚本->保存到OS下的某个sql文件

然后在目的服务器上运行刚才保存下来的创建作业的sql脚本。( 如果建作业的用户或者提醒的用户不存在, 则会出错; 我们需要在目的服务器上建立相关的WINDOWS用户或者SQL Server数据库登录, 也可以修改创建作业的脚本, 把目的服务器上不存在的用户替换成已经有的用户。如果生成日志的物理文件目录不存在,也应该做相关的修改,例如d:/区转f:/区等字符串的 @command 命令里有分隔符号 go 也会出错, 可以把它去掉)

exec   master..xp_cmdshell   @cmd

@cmd是你要执行的语句

 

 

在查询分析器中执行sql文件    
master.dbo.xp_cmdshell     'osql     -U     用户名     -P     密码     -i     c:/***.sql '
--在查询分析器中执行sql文件    
master.dbo.xp_cmdshell     'osql     -U     SA     -P     12345     -i     D:/kkk/SQL/datalength.sql '

 

xp_cmdshell
以操作系统命令行解释器的方式执行给定的命令字符串,并以文本行方式返回任何输出。授予非管理用户执行   xp_cmdshell   的权限。


说明     在   Microsoft®   Windows®   98   操作系统中执行   xp_cmdshell   时,将不把   xp_cmdshell   的返回代码设置为唤醒调用的可执行文件的进程退出代码。返回代码始终为   0。


语法
xp_cmdshell   { 'command_string '}   [,   no_output]

参数
'command_string '

是在操作系统命令行解释器上执行的命令字符串。command_string   的数据类型为   varchar(8000)   或   nvarchar(4000),没有默认值。command_string   不能包含一对以上的双引号。如果由   command_string   引用的文件路径或程序名称中有空格,则需要使用一对引号。如果使用嵌入空格不方便,可考虑使用   FAT   8.3   文件名作为解决办法。

no_output

是可选参数,表示执行给定的   command_string,但不向客户端返回任何输出。

返回代码值
0(成功)或   1(失败)

结果集
执行下列   xp_cmdshell   语句将返回当前目录的目录列表。

xp_cmdshell   'dir   *.exe '

行以   nvarchar(255)   列的形式返回。

执行下列   xp_cmdshell   语句将返回随后的结果集:

xp_cmdshell   'dir   *.exe ',   NO_OUTPUT

下面是结果:

The   command(s)   completed   successfully.

注释
xp_cmdshell   以同步方式操作。在命令行解释器命令执行完毕之前,不会返回控制。

当授予用户执行权限时,用户能在   Microsoft   Windows   NT®   命令行解释器上执行运行   Microsoft   SQL   Server™   的帐户有权执行的任何操作系统命令。

默认情况下,只有   sysadmin   固定服务器角色的成员才能执行此扩展存储过程。但是,也可以授予其他用户执行此存储过程的权限。  

当作为   sysadmin   固定服务器角色成员的用户唤醒调用   xp_cmdshell   时,将在运行   SQL   Server   服务的安全上下文中执行   xp_cmdshell。当用户不是   sysadmin   组的成员时,xp_cmdshell   将模拟使用   xp_sqlagent_proxy_account   指定的   SQL   Server   代理程序的代理帐户。如果代理帐户不能用,则   xp_cmdshell   将失败。这只是针对于   Microsoft®   Windows   NT®   4.0   和   Windows   2000。在   Windows   9.x   上,没有模拟,且   xp_cmdshell   始终在启动   SQL   Server   的   Windows   9.x   用户的安全上下文下执行。


说明     在早期版本中,获得   xp_cmdshell   执行权限的用户在   MSSQLServer   服务的用户帐户上下文中运行命令。可以通过配置选项配置   SQL   Server,以便对   SQL   Server   无   sa   访问权限的用户能够在   SQLExecutiveCmdExec   Windows   NT   帐户的上下文中运行   xp_cmdshell。在   SQL   Server   7.0   中,该帐户称为   SQLAgentCmdExec。现在,不是   sysadmin   固定服务器角色成员的用户将在该帐户上下文中运行命令,而无需再进行配置更改。


权限

 

A.   返回可执行文件列表
下例显示执行目录命令的   xp_cmdshell   扩展存储过程。

EXEC   master..xp_cmdshell   'dir   *.exe '

B.   使用   Windows   NT   net   命令
下例显示   xp_cmdshell   在存储过程中的使用。下例先用   net   send   通知用户   SQL   Server   即将关闭,然后用   net   pause   暂停服务器,最后用   net   stop   关闭服务器。

CREATE   PROC   shutdown10
AS
EXEC   xp_cmdshell   'net   send   /domain:SQL_USERS   ' 'SQL   Server   shutting   down  
      in   10   minutes.   No   more   connections   allowed. ',   no_output
EXEC   xp_cmdshell   'net   pause   sqlserver '
WAITFOR   DELAY   '00:05:00 '
EXEC   xp_cmdshell   'net   send   /domain:   SQL_USERS   ' 'SQL   Server   shutting   down  
      in   5   minutes. ',   no_output
WAITFOR   DELAY   '00:04:00 '
EXEC   xp_cmdshell   'net   send   /domain:SQL_USERS   ' 'SQL   Server   shutting   down  
      in   1   minute.   Log   off   now. ',   no_output
WAITFOR   DELAY   '00:01:00 '
EXEC   xp_cmdshell   'net   stop   sqlserver ',   no_output

C.   不返回输出  
下例使用   xp_cmdshell   执行命令字符串,且不向客户端返回输出。

USE   master
EXEC   xp_cmdshell   'copy   c:/sqldumps/pubs.dmp   //server2/backups/sqldumps ',  
      NO_OUTPUT

D.   使用返回状态
在下例中,xp_cmdshell   扩展存储过程也给出了返回状态。返回代码值存储在变量   @result   中。

DECLARE   @result   int
EXEC   @result   =   xp_cmdshell   'dir   *.exe '
IF   (@result   =   0)
      PRINT   'Success '
ELSE
      PRINT   'Failure '

E.   将变量内容写入文件  
下例将   @var   变量的内容写入当前服务器目录下名为   var_out.txt   的文件中。

DECLARE   @cmd   sysname,   @var   sysname
SET   @var   =   'Hello   world '
SET   @cmd   =   'echo   '   +   @var   +   '   >   var_out.txt '
EXEC   master..xp_cmdshell   @cmd

F.   将命令的结果捕获到文件
下例将当前目录的内容写入当前服务器目录中名为   dir_out.txt   的文件中。

DECLARE   @cmd   sysname,   @var   sysname
SET   @var   =   'dir/p '
SET   @cmd   =   @var   +   '   >   dir_out.txt '
EXEC   master..xp_cmdshell   @cmd

定时作业的制定

企业管理器 
--管理 
--SQL Server代理 
--右键作业 
--新建作业 
--"常规"项中输入作业名称 
--"步骤"项 
--新建 
--"步骤名"中输入步骤名 
--"类型"中选择"Transact-SQL 脚本(TSQL)" 
--"数据库"选择执行命令的数据库 
--"命令"中输入要执行的语句: 
  EXEC 存储过程名 ... --该存储过程用于创建表 

--确定 
--"调度"项 
--新建调度 
--"名称"中输入调度名称 
--"调度类型"中选择你的作业执行安排 
--如果选择"反复出现" 
--点"更改"来设置你的时间安排  


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

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

 

SQL2005:管理--维护计划 

右键"维护计划"--新建维护计划--输入维护计划名称--这样会出现创建维护计划的窗口然后, 在左边的工具箱中(没有的话, 按Ctrl+Alt+X), 将"执行T_sql语句任务"拖到中间的黄色区域 

双击拖出来的这个任务, 会出现设计属性的窗口 

在SQL语句中写你要执行的语句. 

单击"计划"后面的"..."按钮, 设置执行的时间计划. 

最后保存就可以了. 
把sql agent服务设置为自动启动 
 

 

可以这样,
1、提交定时任务时,判断执行时间是否在1小时内,如果1小时内,马上添加作业,否则,暂不增加,只记录到表。
2、表记录增加作业名,是否增加作业、是否过时删除作业等信息。
3、增加一个作业管理的作业,每小时执行一次,工作是: 
  a、检查是否有1小时内需要执行的任务,有则添加作业
  b、检查是否有过时作业,有则删除之


注意时间控制,不要有留空,否则会造成部分任务得不到执行

 

多处转载就不附上网址

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值