使用PHP备份SQL Server数据库

问题描述

我正在尝试使用PHP备份调用存储过程的MS SQL数据库。

当我在SSMS上执行de SP时,一切正常。但是,当我从PHP脚本调用它时,我在备份文件夹中看到一个“ .bak”,并且在PHP完成处理后,BackUp.bak文件消失了。

这是存储过程:

DECLARE @date VARCHAR(10)
SET @date = (SELECT date FROM tbl_date)

Declare @fileName VARCHAR(100)
SET @fileName = ('C:\db_backup\BackUp_' + @date + '.bak')

BACKUP DATABASE DbName
TO DISK = @fileName
   WITH FORMAT,MEDIANAME = 'SQLServerBackups',NAME = 'Full Backup of DbName';

下面是我称为SP的PHP代码:

$serverName = "server";
$connectionInfo = array( "Database"=>"DbName","UID"=>"UserName","PWD"=>"P@ssword","CharacterSet"=>"UTF-8","ReturnDatesAsStrings" => "false");
$conn = sqlsrv_connect( $serverName,$connectionInfo);

$BackupDB = "Exec DBBackup";
sqlsrv_query($conn,$BackupDB);

我正在运行Apache 2.4.46和SQL Server Express 2019。

我的目标是使用PHP创建一个“ .bak”文件。

我尝试使用SP是因为原始代码是用Classic ASP编写的,并且可以通过这种方式完美地工作。

我愿意尝试不同的方法。

谢谢。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)