前言
在工作中,我们经常需要把远程的数据库,同步一份到本地用于开发测试,这时候就需要复制一份数据库到本地来,具体操作,下文带大家一起学习下
一、前置知识
sql server 已安装,因为我备份的是sql server 2019版本的;
所以安装sql server2019 方法:
https://blog.csdn.net/SR02020/article/details/105361807
在微软的SQL Server 2000 数据库有三种类型的文件:
类型 缩写 中文意思
: mdf primary data file 主要数据文件
: ndf secondary data files 次要数据文件
: ldf Log data files 事务日志文件
主要数据文件:(扩展名.mdf是 primary data file 的缩写)
主要数据文件包含数据库的启动信息,并指向数据库中的其他文件。用户数据和对象可存储在此文件中,也可以存储在次要数据文件中。每个数据库有一个主要数据文件。
次要数据文件(扩展名.ndf是Secondary data files的缩写)
次要数据文件是可选的,由用户定义并存储用户数据。通过将每个文件放在不同的磁盘驱动器上,次要文件可用于将数据分散到多个磁盘上。另外,如果数据库超过了单个 Windows 文件的最大大小,可以使用次要数据文件,这样数据库就能继续增长。
事务日志 (扩展名.ldf是Log data files的缩写)
事务日志文件保存用于恢复数据库的日志信息。每个数据库必须至少有一个日志文件。
认识迁移脚本语法
restore database 数据库名
from disk='备份文件路径'
with move '数据库文件名'
to '数据库文件放置路径',
move '日志文件名'
to '日志文件存放置路径'
USE [master] RESTORE DATABASE [XXXMasterDB] FROM
DISK = N'D:\xxx\publish_Backup\XXXMasterDB.bak' WITH FILE = 1,
MOVE N'XXXMasterDB'
TO N'C:\Program Files\Microsoft SQL Server\MSSQL16.MYSQLSERVER\MSSQL\DATA\XXXMasterDB.mdf',
MOVE N'XXXMasterDBB_log'
TO N'C:\Program Files\Microsoft SQL Server\MSSQL16.MYSQLSERVER\MSSQL\DATA\xxxMasterDB_log.ldf',
NOUNLOAD, STATS = 5
运行脚本可能遇到的错误,如果XXXMasterDB 已经存在,就删除或者换一个名字。
如果访问文件的权限不够,点击对应的文件,如上例子 xx/XXXMasterDB.mdf, 设置文件的权限。
二、具体操作步骤
这里用的是Mircosoft SQL Server Mangement Studio
1.备份数据库
备份数据库
2.还原数据库
连接本地数据后(前提需要安装sqlserver,创建本地数据库),新建查询,运行上述脚本,路径,名字要对应自己实际情况。
运行正常就可以
我这里遇到的问题,成功还原数据库后,点击某一个表,设计出现下面的提示信息
我安装的是2022的版本sql server,网上说是版本问题。也有可能是我的Mircosoft SQL Server Mangement Studio 版本问题,这里我选择重新安装Sql Server 为2019
查看版本
select @@version
我安装的sql server 版本
Microsoft SQL Server 2022 (RTM) - 16.0.1000.6 (X64)
备份的数据是下面的版本
Microsoft SQL Server 2019 (RTM) - 15.0.2000.5 (X64)
根据上述我重新安装 sql server 2019,成功解决上述问题;
总结
本文先带大家了解sqlserver备份还原数据库需要用的 .BAK .LDF 文件的大概意思。这里主要描述是还原数据库,至于备份数据库,还有sql server的安装给出了链接安装操作也可以达成目标,另外还顺便提了一嘴,我在实际操作过程遇到的版本不兼容的问题。