0

我想使用参数化查询重构以下 sql 查询。可能吗?

 string cmd= $@" IF EXISTS(select * from sys.databases where name='{ dbname}')
                                    ALTER DATABASE[{ dbname}] 
                                    SET OFFLINE WITH ROLLBACK IMMEDIATE;

                                    RESTORE DATABASE[{ dbname}]  
                                    FROM DISK = '{backupFile}'
                                    WITH REPLACE,
                                    MOVE '{mdfFileName}' TO '{sqlDataFolderPath}{dbname}.MDF',   
                                    MOVE '{logFileName}' TO '{sqlDataFolderPath}{dbname}.LDF';

                                    ALTER DATABASE[{ dbname}] 
                                    SET ONLINE ";

            SqlCommand cmd= con.CreateCommand();
            command.CommandText = sqlCommand;
            command.ExecuteNonQuery();

作为第一步,我使用参数化查询通过 RESTORE FILELISTONLY FROM DISK = @backupFilePath 检索有关 mdf 和 ldf 的信息。下一步应该是还原操作。目前仅使用上述方法,但我想对其进行重构以解决声纳报告的安全热点(sql注入)。

更新:

我尝试使用与 BACKUP 相同的方法,但没有成功,不会引发错误,但不会移动 mdf、ldf 文件。

string sqlDynamicQuery = "DECLARE @sql nvarchar(max) = (" +
                                         "SELECT 'ALTER DATABASE ' + QUOTENAME(name) + " +
                                         "' SET OFFLINE WITH ROLLBACK IMMEDIATE;'" +
                                         "+ ' RESTORE DATABASE ' + QUOTENAME(name) + " +
                                         "' FROM DISK = @backupfilepath WITH REPLACE, " +
                                         "MOVE @mdfFileName TO @mdfFilePath, " +
                                         "MOVE @logFileName TO @ldfFilePath ' " +
                                         "+ ' ALTER DATABASE ' + QUOTENAME(name) +" +
                                         "'SET ONLINE ' from sys.databases where name= @database); "+
                                         "EXEC sp_executesql "+
                                         "@sql, " +
                                         "N'@backupfilepath nvarchar(128), @mdfFileName nvarchar(128),  @mdfFilePath  nvarchar(128), @logFileName nvarchar(128),  @ldfFilePath  nvarchar(128)', "+
                                         "@backupfilepath = @backupfilepath, "+
                                         "@mdfFileName = @mdfFileName, "+
                                         "@mdfFilePath = @mdfFilePath, "+
                                         "@logFileName = @logFileName, "+
                                         "@ldfFilePath = @ldfFilePath; ";

                using (SqlCommand sqlCmd = new SqlCommand(sqlDynamicQuery, _sqlConnection))
                {
                    sqlCmd.Parameters.Add("@database", SqlDbType.NVarChar, 128).Value = databaseName;
                    sqlCmd.Parameters.Add("@backupfilepath", SqlDbType.NVarChar, 128).Value = backupFile;
                    sqlCmd.Parameters.Add("@mdfFileName", SqlDbType.NVarChar, 128).Value = model.MdfFileName;
                    sqlCmd.Parameters.Add("@mdfFilePath", SqlDbType.NVarChar, 128).Value = Path.Combine(_sqlDataFolderPath, databaseName + ".MDF");
                    sqlCmd.Parameters.Add("@logFileName", SqlDbType.NVarChar, 128).Value = model.LogFileName;
                    sqlCmd.Parameters.Add("@ldfFilePath", SqlDbType.NVarChar, 128).Value = Path.Combine(_sqlDataFolderPath, databaseName + ".LDF");

                    sqlCmd.ExecuteNonQuery();
                }
   

我也试过ssms

DECLARE @database nvarchar(128)
DECLARE @backupfilepath nvarchar(128)
DECLARE @mdfFilePath nvarchar(128)
DECLARE @ldfFilePath nvarchar(128)
DECLARE @mdfFileName nvarchar(128)
DECLARE @logFileName nvarchar(128)

SET @database = 'v1'
set @backupfilepath = 'C:\\Data\\MyDocs\\DatabaseBak\\v1.bak'
SET @mdfFileName = 'p1'
SET @logFileName = 'p1_log'
SET @mdfFilePath = 'C:\\Program Files\\Microsoft SQL Server\\MSSQL12.SQLEXPRESS\\MSSQL\\DATA\\v1.MDF'
SET @ldfFilePath = 'C:\\Program Files\\Microsoft SQL Server\\MSSQL12.SQLEXPRESS\\MSSQL\\DATA\\v1.LDF'



DECLARE @sql nvarchar(max) = (SELECT 'ALTER DATABASE ' + QUOTENAME(name) + ' SET OFFLINE WITH ROLLBACK IMMEDIATE;' +  ' RESTORE DATABASE ' + QUOTENAME(name) + ' FROM DISK = @backupfilepath WITH REPLACE, MOVE @mdfFileName TO @mdfFilePath, MOVE @logFileName TO @ldfFilePath '+ ' ALTER DATABASE ' + QUOTENAME(name) + 'SET ONLINE  ' from sys.databases where name= @database);
print @sql
EXEC sp_executesql
    @sql,
    N'@backupfilepath nvarchar(128), @mdfFileName nvarchar(128),  @mdfFilePath  nvarchar(128), @logFileName nvarchar(128),  @ldfFilePath  nvarchar(128)',
    @backupfilepath = @backupfilepath,
    @mdfFileName = @mdfFileName,
    @mdfFilePath = @mdfFilePath,
    @logFileName = @logFileName,
    @ldfFilePath = @ldfFilePath;

更新:

它现在可以在 SSMS 上运行:

DECLARE @database nvarchar(128)
DECLARE @backupfilepath nvarchar(128)
DECLARE @mdfFilePath nvarchar(128)
DECLARE @ldfFilePath nvarchar(128)
DECLARE @mdfFileName nvarchar(128)
DECLARE @logFileName nvarchar(128)

SET @database = 'v1'
set @backupfilepath = 'C:\\Data\\MyDocs\\DatabaseBak\\v1.bak'
SET @mdfFileName = 'p1'
SET @logFileName = 'p1_log'
SET @mdfFilePath = 'C:\\Program Files\\Microsoft SQL Server\\MSSQL12.SQLEXPRESS\\MSSQL\\DATA\\v1.MDF'
SET @ldfFilePath = 'C:\\Program Files\\Microsoft SQL Server\\MSSQL12.SQLEXPRESS\\MSSQL\\DATA\\v1.LDF'


DECLARE @SQLString nvarchar(max) ='IF EXISTS(select * from sys.databases where name='+'''' + @database +''''+')'+
   'ALTER DATABASE [' + @database + '] ' +
   'SET OFFLINE WITH ROLLBACK IMMEDIATE ' +
   'RESTORE DATABASE ['+@database +
   '] FROM  DISK ='+ '''' + @backupfilepath +''''+
   ' WITH  REPLACE,  '+
   'MOVE '+''''+@mdfFileName+''''+ ' TO '+ '''' + @mdfFilePath +''''+',  '+
   'MOVE '+''''+@logFileName+''''+ ' TO '+ '''' + @ldfFilePath +''''+';  '+
   'ALTER DATABASE [' + @database + '] ' +
   'SET ONLINE '
print @SQLString


EXEC sp_executesql
    @SQLString,
    N'@database nvarchar(128), @backupfilepath nvarchar(128), @mdfFileName nvarchar(128),  @mdfFilePath  nvarchar(128), @logFileName nvarchar(128),  @ldfFilePath  nvarchar(128)',
    @database = @database,
    @backupfilepath = @backupfilepath,
    @mdfFileName = @mdfFileName,
    @mdfFilePath = @mdfFilePath,
    @logFileName = @logFileName,
    @ldfFilePath = @ldfFilePath;
4

0 回答 0