在SQL Server 2008 Management Studio中执行SP时出现以下错误:
Msg 208, Level 16, State 6, Procedure BackupDB, Line 36
Invalid object name 'dbo.BackupDB'.
use [Master];
go
alter procedure dbo.BackupDB
@dbName varchar(128),
@path varchar(256)
as
begin
declare @device1 varchar(256);
declare @device2 varchar(256);
declare @path1 varchar(256);
declare @path2 varchar(256);
declare @sql varchar(500);
if @dbName is null or @path is null
raiserror('Error: Database name and/or Path missing', 10, 1);
if not exists(select * from sys.databases where name = @dbName)
raiserror('Database %s does not exist', 10, 1, @dbName);
begin
set @sql = 'ALTER DATABASE ' + @dbName + '; SET RECOVERY FULL;';
exec(@sql);
set @device1 = @dbName + '_Data';
set @device2 = @dbname + '_Log';
set @path1 = @path + '\' + @dbname + '_Data.bak';
set @path2 = @path + '\' + @dbname + '_Log.bak';
print 'path :' + @path1;
print 'path :' + @path2;
exec sp_addumpdevice 'disk', @device1, @path1;
exec sp_addumpdevice 'disk', @device2, @path2;
backup database @dbName TO @device1;
backup log @dbName TO @device2;
end
end
go
答案 0 :(得分:1)
这表示您尚未创建该过程。再次以CREATE PROCEDURE
运行它答案 1 :(得分:1)
变化:
alter procedure dbo.BackupDB
为:
create procedure dbo.BackupDB as
答案 2 :(得分:0)
需要创建SP。 sp的顶部可以是:
使用[Master];
去
CREATE程序dbo.BackupDB
- 更改程序dbo.BackupDB
@dbName varchar(128),
@path varchar(256)
作为
开始
Alter系列被注释掉了。然后在执行程序&创建它你可以注释掉创建行&取消注释替换行,例如
使用[Master];
去
--CREATE程序dbo.BackupDB
改变程序dbo.BackupDB
@dbName varchar(128),<br>
@path varchar(256)<br>
如
开始
希望这有帮助,
卡托