34,593
社区成员
发帖
与我相关
我的任务
分享
/*
这种情况,一般是因为,在sqlserver中建立了针对其他数据库的链接,并且要在存储过程里面,调用该连接数据,直接创建存储过程汇报上面的错误,一种比较懒人的方法是,
打开SQL查询分析器,将该存储过程代码,拷贝过来,直接执行,在这里系统会默认代上 ANSI_NULLS 和 ANSI_WARNINGS 的值,然后刷新企业管理器,就可以看到了,以后就可以正常的修改。
*/
create proc pp
as
declare @sql varchar(4000)
declare @s1 varchar(100),
@s2 varchar(100),
@s3 varchar(100)
set @s1='a'+convert(varchar(8),getdate(),112) -- 192.168.0.1 中今天生成的表名
set @s2='q'+convert(varchar(8),getdate(),112) -- 192.168.0.2 中今天生成的表名
set @s3='a'+convert(varchar(8),getdate()+1,112) -- 192.168.0.3 中今天生成的表名
if object_id(@s3)is null
begin
set @sql='create table '+@s3+'(东桥原煤量 int,东桥原煤量累计 int,老厂石灰石量累计 int,老厂脱硫消耗电量 int,新厂石灰石量累计 int,新厂脱硫消耗电量 int,date datetime)'
exec(@sql)
end
-- 判断192.168.0.1 的表存在
if exists (select 1 from openrowset( 'SQLOLEDB', '192.168.0.1'; 'sa';'' , gongkong.dbo.sysobjects) where name=@s1)
begin
set @sql='insert '+@s3+ ' select * from openrowset( ''SQLOLEDB'', ''192.168.0.1''; ''sa'';'''' , ''select 东桥原煤量,东桥原煤量累计, from dongning.dbo.'+@s1+''')'
exec(@sql)
end
-- 判断192.168.0.2 的表存在
if exists (select 1 from openrowset( 'SQLOLEDB', '192.168.0.2'; 'sa';'' , ngongkong.dbo.sysobjects) where name=@s2)
begin
set @sql='insert '+@s3+ ' select * from openrowset( ''SQLOLEDB'', ''192.168.0.2''; ''sa'';'''' , ''select 老厂石灰石量累计,老厂脱硫消耗电量,新厂石灰石量累计,新厂脱硫消耗电量 from ndongning.dbo.'+@s2+''')'
exec(@sql)
end
go
create proc pp
as
declare @sql varchar(4000)
declare @s1 varchar(100),
@s2 varchar(100),
@s3 varchar(100)
set @s1='a'+convert(varchar(8),getdate(),112) -- 192.168.0.1 中今天生成的表名
set @s2='q'+convert(varchar(8),getdate(),112) -- 192.168.0.2 中今天生成的表名
set @s3='a'+convert(varchar(8),getdate()+1,112) -- 192.168.0.3 中今天生成的表名
if object_id(@s3)is null
begin
set @sql='create table '+@s3+'(南桥煤量 int,北桥煤量 int,date datetime)'
exec(@sql)
end
-- 判断192.168.0.1 的表存在
if exists (select 1 from openrowset( 'SQLOLEDB', '192.168.0.1'; 'sa';'' , dongning.dbo.sysobjects) where name=@s1)
begin
set @sql='insert '+@s3+ ' select * from openrowset( ''SQLOLEDB'', ''192.168.0.1''; ''sa'';'''' , ''select 南桥煤量,北桥煤量 from dongning.dbo.'+@s1+''')'
exec(@sql)
end
-- 判断192.168.0.2 的表存在
if exists (select 1 from openrowset( 'SQLOLEDB', '192.168.0.2'; 'sa';'' , ndongning.dbo.sysobjects) where name=@s2)
begin
set @sql='insert '+@s3+ ' select * from openrowset( ''SQLOLEDB'', ''192.168.0.2''; ''sa'';'''' , ''select 南桥煤量,北桥煤量 from ndongning.dbo.'+@s2+''')'
exec(@sql)
end
go
定时作业的制定
企业管理器
--管理
--SQL Server代理
--右键作业
--新建作业
--"常规"项中输入作业名称
--"步骤"项
--新建
--"步骤名"中输入步骤名
--"类型"中选择"Transact-SQL 脚本(TSQL)"
--"数据库"选择执行命令的数据库
--"命令"中输入要执行的语句:
EXEC 存储过程名 ... --该存储过程用于创建表
--确定
--"调度"项
--新建调度
--"名称"中输入调度名称
--"调度类型"中选择你的作业执行安排
--如果选择"反复出现"
--点"更改"来设置你的时间安排
然后将SQL Agent服务启动,并设置为自动启动,否则你的作业不会被执行
设置方法:
我的电脑--控制面板--管理工具--服务--右键 SQLSERVERAGENT--属性--启动类型--选择"自动启动"--确定.