دسته بندی ها
21:45 1402/08/16

بکاپ گرفتن از دیتابیس در برنامه در حال اجرا در Asp.net Core

مشخصات سوال کننده :
کاربر : hajyani     امتیاز کاربر : 0     رتبه کاربر : 7150
دسته بندی : Asp.net Core Sql Server

به این سوال امتیاز بدهید    0
تعداد بازدید این سوال : 1493
هوش مصنوعی

پاسخ هوش مصنوعی

برای تهیه بکاپ از دیتابیس SQL Server در ASP.NET Core و فراهم کردن امکان دانلود آن، می توانید از کد زیر استفاده کنید:

ابتدا باید یک متد برای گرفتن بکاپ بنویسید:

using System.Data.SqlClient;
using System.IO;
using Microsoft.AspNetCore.Mvc;

public class BackupController : Controller
{
    private readonly string _connectionString = "your_connection_string_here";

    public IActionResult CreateBackup()
    {
        string backupFileName = $"Backup_{DateTime.Now:yyyyMMddHHmmss}.bak";
        string backupFilePath = Path.Combine("C:\\Backups", backupFileName);

        using (SqlConnection connection = new SqlConnection(_connectionString))
        {
            connection.Open();
            SqlCommand command = new SqlCommand($"BACKUP DATABASE [your_database_name] TO DISK = '{backupFilePath}'", connection);
            command.ExecuteNonQuery();
        }

        return File(System.IO.File.ReadAllBytes(backupFilePath), "application/octet-stream", backupFileName);
    }
}

در این کد:

  • شما باید your_connection_string_here و your_database_name را با مقادیر مربوط به دیتابیس خود جایگزین کنید.
  • به پوشه C:\Backups دسترسی نوشتن بدهید یا پوشه مورد نظر خود را انتخاب کنید.

سپس در فایل Startup.cs خود، مطمین شوید که کنترلرها به درستی پیکربندی شده اند:

public void ConfigureServices(IServiceCollection services)
{
    services.AddControllersWithViews();
}

در نهایت، دکمه ای در پنل ادمین اضافه کنید که با کلیک بر روی آن، متد CreateBackup اجرا شود:

<a href="@Url.Action("CreateBackup", "Backup")">گرفتن بکاپ</a>
به این پاسخ امتیاز بدهید    0
امتیاز: - رتبه: -
پاسخ دهنده : fateme 13:16 1402/08/18

بهترین کار این هست که روی سرور Job ایجاد کنید و به طور منظم بکاپ گیری های خودتون رو تنظیم کنید. لینک زیر رو مطالعه بفرمایید به طور کامل آموزش ایجاد Job روی سرور رو نوشته.

آموزش ایجاد Backup در Sql Server به صورت زمانبندی شده

نکته بعدی اینه که بکاپ فقط روی سرور ایجاد میشه. یعنی شما نمی تونید به صورت ریموت یک بکاپ بگیرید و فایل بکاپ رو جایی غیر از سرور ذخیره سازی کنید. شما نهایتا می تونید فایل های بکاپی که ایجاد شده رو از روی سرور بردارید و به جای دیگه منتقل کنید.

به این پاسخ امتیاز بدهید    0
امتیاز: 1635 رتبه: 2
برای ارسال پاسخ لطفا وارد حساب کاربری خود شوید.   ورود