当前位置: 首页 > news >正文

全国哪个餐饮品牌的网站做的好seo需要掌握什么技能

全国哪个餐饮品牌的网站做的好,seo需要掌握什么技能,国内域名服务商,建设个人你网站在日常的数据库管理中,数据的误删操作是难以避免的。为了确保数据的安全性和完整性,我们必须采取一些措施来进行数据的备份和恢复。本文将详细介绍如何在 SQL Server 中进行数据的备份和恢复操作,特别是在发生数据误删的情况下。假设我们已经…

在日常的数据库管理中,数据的误删操作是难以避免的。为了确保数据的安全性和完整性,我们必须采取一些措施来进行数据的备份和恢复。本文将详细介绍如何在 SQL Server 中进行数据的备份和恢复操作,特别是在发生数据误删的情况下。假设我们已经开启了全量备份,并且在误操作之前有一个全量备份文件。


一、模拟误删

1. 创建表并插入测试数据

首先,我们需要创建一个名为 “Test” 的数据库,并在其中创建一个名为 “Student” 的表。该表将包含一些测试数据。

SSMS 连接本地 SQL Server。

在这里插入图片描述

创建新数据库 “Test”。

【图002】

创建数据库 “Test”,并在该库内创建数据表 “Student”

-- 创建数据库
CREATE DATABASE Test;-- 使用 Test 数据库
USE Test;-- 创建 Student 表
CREATE TABLE Student (id INT IDENTITY(1,1) PRIMARY KEY,name NVARCHAR(255) NOT NULL,phone NVARCHAR(50) NOT NULL,gender NVARCHAR(10) NOT NULL,created_at DATETIME DEFAULT GETDATE()
);-- 插入十条测试数据
INSERT INTO Student (name, phone, gender, created_at) VALUES 
('Alice', '1234567890', 'Female', GETDATE()),
('Bob', '0987654321', 'Male', GETDATE()),
('Cathy', '1231231234', 'Female', GETDATE()),
('David', '3213214321', 'Male', GETDATE()),
('Eva', '5556667777', 'Female', GETDATE()),
('Frank', '8889990000', 'Male', GETDATE()),
('Grace', '2223334444', 'Female', GETDATE()),
('Henry', '4445556666', 'Male', GETDATE()),
('Ivy', '1112223333', 'Female', GETDATE()),
('Jack', '7778889999', 'Male', GETDATE());

记录本次操作时间为:2024-07-23 17:30:45

在这里插入图片描述


2. 数据库全量备份

恢复的前提是数据库在误删前进行过一次全量备份。

全量备份流程:

右键 “Test” 数据库,点击备份(Back Up),备份文件命名为 “testDB.bak”,存储在自定义目录,我存储在 “D:\testDB.bak”。

在这里插入图片描述

在这里插入图片描述

备份成功。

在这里插入图片描述

记录本次操作时间为:2024-07-23 17:32:30


3. 未备份的新操作

如果我们的数据库全量备份之后没有任何操作,那这个还原是毫无难度的,草履虫也会。本篇重点讲如果全量备份之后,再有为备份的新操作该如何处理,这也符合实际应用中的场景。

-- 插入五条测试数据
INSERT INTO Student (name, phone, gender, created_at) VALUES 
('Lily', '1114447777', 'Female', GETDATE()),
('Mike', '2225558888', 'Male', GETDATE()),
('Nina', '3336669999', 'Female', GETDATE()),
('Oscar', '4447770000', 'Male', GETDATE()),
('Paul', '5558881111', 'Male', GETDATE());

在这里插入图片描述

记录本次操作时间为:2024-07-23 17:35:14


4. 模拟数据误删

为了模拟数据误删的情况,我们将进行一次全量更新操作,导致所有记录的手机号码(phone)字段丢失。

-- 模拟全量更新操作,导致手机号码丢失
UPDATE Student
SET phone = NULL;

在这里插入图片描述

执行上述 SQL 脚本后,Student 表中的所有记录的 phone 字段将被更新为 NULL,模拟了数据误删的情况。

在这里插入图片描述

记录本次操作时间为:2024-07-23 17:35:41

这是数据维护中经常遇到的问题,因为某些原因导致 Where 条件的子项查询没有生效,导致全量更新,等同于某一列被直接删除。还有一些 Delete From / Drop Table 之类的情况,其实和这个的恢复方式一样。


二、数据恢复步骤

1. 备份日志

在误删发生后,我们需要备份当前的事务日志,以确保在恢复过程中不会丢失任何数据。

-- 备份当前的事务日志
BACKUP LOG Test TO DISK='d:\testLOG.bak' WITH FORMAT
GO

在这里插入图片描述

记录本次操作时间为:2024-07-23 17:37:16


2. 还原数据库到指定时间点

接下来,我们将还原数据库到误操作之前的状态。这个过程包括还原之前的全量备份和刚刚备份的事务日志(截至到误删前的部分)。

在 SQL Server Management Studio 中,右键单击要还原的数据库(Test),选择“任务” -> “还原” -> “数据库”

在“选项”标签中,勾选“关闭现有连接到目标数据库”,选择 之前的全量备份 和 刚刚备份的事务日志。

在这里插入图片描述

在这里插入图片描述

在通用里,选择一个还原到的具体时间点。这里的时间点如果记不清了,则需要我们去尽可能推算,因为生产数据时刻在变化,尽可能恢复到误删前的前一刻的数据可以避免更多的损失。

在这里插入图片描述

这里我们的误删操作发生在:2024-07-23 17:35:41。

因此,我们选择还原到这个时间的前一刻,我选择 2024-07-23 17:35:30。

在这里插入图片描述

点击“确定”开始还原。

在这里插入图片描述

还原成功。


3. 检验恢复结果

还原完成后,我们需要验证数据是否已经被成功恢复。

-- 查看 Student 表中的数据
SELECT TOP (1000) [id],[name],[phone],[gender],[created_at]FROM [Test].[dbo].[Student]

执行上述查询语句后,我们可以看到所有记录的 phone 字段已经被恢复到误操作之前的状态。

在这里插入图片描述


4. 恢复数据库可读写

从刚刚的截图上我们看到,虽然数据被恢复了,但是因为使用了日志事务,所以Test数据库变成了StandBy/ReadOnly状态。当前状态下,数据库是无法被写入的,我们需要解除这种状态。

-- 切换到 master 数据库
USE master;-- 在主服务器上移除日志传送配置
EXEC master.dbo.sp_delete_log_shipping_primary_secondary@primary_database = 'Test',            -- 主数据库名称@secondary_server = '<SecondaryServerName>', -- 备用服务器名称@secondary_database = 'Test';          -- 备用数据库名称-- 在主服务器上移除主数据库的日志传送配置
EXEC master.dbo.sp_delete_log_shipping_primary_database@database = 'Test';                    -- 主数据库名称-- 在备用服务器上移除日志传送配置
EXEC master.dbo.sp_delete_log_shipping_secondary_database@secondary_database = 'Test';          -- 备用数据库名称-- 恢复数据库
RESTORE DATABASE Test WITH RECOVERY;-- 将数据库设置为读写模式
ALTER DATABASE Test SET READ_WRITE;

我们刷新数据库,看到数据库Test已经变为可写入的正常状态了。

在这里插入图片描述


三、SQL Server 数据误删总结

通过本文的介绍,我们学习了如何在 SQL Server 中进行数据的备份和恢复操作,特别是在数据误删的情况下。数据误删是数据库管理中一个常见而严重的问题,如果没有有效的备份和恢复策略,可能会导致无法挽回的损失。

1. 数据备份策略

定期备份是保障数据安全的最有效手段之一。SQL Server 提供了多种备份策略,包括:

  • 完全备份:备份整个数据库的所有数据。这种备份方式最为全面,但也最耗时和占用空间最多。
  • 差异备份:备份自上次完全备份以来所有更改的数据。它比完全备份更快,但仍然需要上次的完全备份来恢复数据。
  • 事务日志备份:备份自上次事务日志备份以来所有更改的事务日志。它允许我们恢复到特定的时间点,非常适合用于数据误删后的恢复。

2. 数据恢复操作

当数据被误删时,正确的恢复操作至关重要。通过以下步骤,我们可以有效地恢复数据:

  1. 识别误删数据的时间点:确定数据被误删的具体时间。
  2. 停止数据库的写操作:防止新的数据写入干扰恢复过程。
  3. 还原最近的完全备份
    RESTORE DATABASE [YourDatabase] FROM DISK = 'C:\Backup\YourDatabase_full.bak' WITH NORECOVERY;
    
  4. 还原最近的差异备份(如果有)
    RESTORE DATABASE [YourDatabase] FROM DISK = 'C:\Backup\YourDatabase_diff.bak' WITH NORECOVERY;
    
  5. 还原事务日志备份,直到误删数据的时间点
    RESTORE LOG [YourDatabase] FROM DISK = 'C:\Backup\YourDatabase_log.trn' WITH STOPAT = 'YYYY-MM-DDTHH:MM:SS', RECOVERY;
    

通过全量备份和事务日志备份,我们能够有效地恢复误删的数据,确保数据的完整性和安全性。希望本文对大家在日常的数据库管理工作中有所帮助。


3. 本文参考资料

  • SQL Server 官方文档
  • SQL Server Management Studio 使用手册
http://www.hrbkazy.com/news/50530.html

相关文章:

  • 哪个工业园区信息化网站做的好揭阳市seo上词外包
  • 大型门户网站建设的意义互联网最赚钱的行业
  • 彭州建设局网站百度客服人工电话95188
  • 网站开发的前端后端黑马程序员培训机构官网
  • 做一个营销型网站多少钱百度pc版网页
  • 网站建设服务条款百度打广告怎么收费
  • 企业邮箱与个人邮箱有什么区别seo1新地址在哪里
  • 微网站地图定位百度推广二级代理商
  • 深圳住房和城乡建设部网站免费的个人网页
  • flash 网站建设做网络优化哪家公司比较好
  • 网站开发论文英文资料做推广的技巧
  • 长春网站优化方式爱站网ip反查域名
  • 如何做视频网站首页竞价账户托管哪家好
  • 戴尔的网站建设360信息流广告平台
  • 推广网站的广告怎样做最新军事头条
  • 有个网站发任务 用手机可以做今日国内新闻最新消息10条新闻
  • 河南航天建设工程有限公司网站google关键词排名查询
  • 贵州省建设厅网站造价工程信息优化大师官方正版下载
  • seo网站优化详解优化大师客服电话
  • 网站开发工具大全西安网站推广
  • 查看邮箱注册过的网站邯郸网站优化公司
  • 帝国网站管理系统教程外贸网站制作公司
  • 政府网站建设方案.doc晋城seo
  • 网站的服务器是什么项目外包平台
  • 企业网站建设管理系统广州seo服务外包
  • bootstrap怎么做响应式网站google chrome download
  • 苹果商店app下载seo优化工作怎么样
  • wordpress和zblogphp站长之家seo查找
  • 医疗网站 seo怎么做制作网站公司
  • 网站建设 软件整站优化外包服务