博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
从Windows迁移SQL Server到Linux
阅读量:5080 次
发布时间:2019-06-12

本文共 1311 字,大约阅读时间需要 4 分钟。

前一篇博客关于SQL Server on Linux的安装,地址:,现在测试把Windows平台下的一个数据库迁移到Linux平台下。

 

1. 环境

Windows: Microsoft SQL Server 2008 R2 (SP3) - 10.50.6000.34 (X64)

Linux: CentOS 7.4,SQL Server 2017 (RC2) - 14.0.900.75 (X64)

 

2. 在Windows下创建备份

在Windows下使用SSMS完整备份数据库

BACKUP DATABASE db1 TO DISK = 'D:\sql_bak\db1\db1.bak'WITHCOMPRESSION, INIT, SKIP, NAME = 'full_backup',STATS = 1GO

code-1: 备份数据库

 

3. 复制备份文件到Liunx

把备份文件复制到Linux,如放到/tmp/下。可以用FTP,或rz等工具。

4. 在Linux下还原数据库

使用终端(如Xshell)连接到Linux。默认数据文件目录在/var/opt/mssql/data/下,如果要指定数据目录的话,可创建自定义目录并赋予相应权限。

mkdir -p /data/mssql_datachown -R mssql:mssql /data/mssql_data

code-2: 创建目录并修改权限

使用sqlcmd连接到数据库

sqlcmd -S localhost -U sa

code-3: 连接到数据库

 

RESTORE DATABASE db1 FROM DISK = '/tmp/db1.bak'WITHMOVE 'db1' TO '/data/mssql_data/db1.mdf',MOVE 'db1_log' TO '/data/mssql_data/db1_log.ldf',STATS = 1, REPLACE, RECOVERYGO

code-4: 还原数据库

 

注意:不能复制并粘贴整个多行命令一次,只能复制每个行后按 enter 键。最后以GO结束,回车后执行。
当然,也可以把上面的还原数据库的命令写到一个文件,再使用sqlcmd执行脚本方式来还原数据库。

sqlcmd -S localhost -U sa -i '/data/mssql_data/restore_db.txt'

code-5: 执行脚本文件还原数据库

5. 查询验证

在Linux下的sqlcmd查询:

 Figure-1: sqlcmd下的查询

 

 

 Figure-2: SSMS下db1数据库的属性(Files)

 

 

在Windows的SSMS连接到Linux下的数据库,发现数据库文件的路径不是Linux的正斜杠,而是Windows的反斜杠;Compatibility level也无法修改。

 Figure-2: SSMS下db1数据库的属性(Options)

 

 

 

Figure-2: SSMS下的查询

 

6. 参考

 

转载于:https://www.cnblogs.com/fishparadise/p/8058085.html

你可能感兴趣的文章
JavaScript 克隆数组
查看>>
eggs
查看>>
oracle 报错ORA-12514: TNS:listener does not currently know of service requested in connec
查看>>
python3 生成器与迭代器
查看>>
java编写提升性能的代码
查看>>
Abstract Factory Pattern
查看>>
list 容器 排序函数.xml
查看>>
《Genesis-3D开源游戏引擎完整实例教程-跑酷游戏篇03:暂停游戏》
查看>>
CPU,寄存器,一缓二缓.... RAM ROM 外部存储器等简介
查看>>
windows下编译FreeSwitch
查看>>
git .gitignore 文件不起作用
查看>>
Alan Turing的纪录片观后感
查看>>
c#自定义控件中的事件处理
查看>>
django Models 常用的字段和参数
查看>>
IOS--沙盒机制
查看>>
使用 JointCode.Shuttle 访问任意 AppDomain 的服务
查看>>
sqlite的坑
查看>>
digitalocean --- How To Install Apache Tomcat 8 on Ubuntu 16.04
查看>>
【题解】[P4178 Tree]
查看>>
Jquery ui widget开发
查看>>