2022-09-25 17:55:41 +08:00
|
|
|
|
+++
|
|
|
|
|
author = "FlintyLemming"
|
|
|
|
|
title = "SQL Server 表迁移"
|
|
|
|
|
slug = "0ea73090a5d54118b3ab9b730fe8fb40"
|
|
|
|
|
date = "2019-10-14"
|
|
|
|
|
description = ""
|
|
|
|
|
categories = ["Coding"]
|
|
|
|
|
tags = ["SQL"]
|
2025-01-23 16:43:06 +08:00
|
|
|
|
image = "https://image.mitsea.com/blog/posts/2019/10/SQL%20Server%20%E8%A1%A8%E8%BF%81%E7%A7%BB/title.avif"
|
2022-09-25 17:55:41 +08:00
|
|
|
|
+++
|
|
|
|
|
|
|
|
|
|
## 手动单表迁移
|
|
|
|
|
|
|
|
|
|
### 迁移表结构
|
|
|
|
|
|
|
|
|
|
1. 先删除原表,删除时注意结构,从最次要的表删起
|
|
|
|
|
2. 对原表右键 - Script Table as - CREATE To - New Query Editor Window
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/10246/102465d1ebbd0b52a8f68a4287ca93dc2b8389e7" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
3. 复制全部的脚本
|
|
|
|
|
4. 在新数据库下,新建一个查询,然后把刚才复制的脚本粘贴过来,修改 USE 的数据库,执行
|
|
|
|
|
|
|
|
|
|
### 迁移表内容
|
|
|
|
|
|
|
|
|
|
1. 由于是单表迁移,不需要使用脚本,直接全查询表的数据
|
|
|
|
|
|
|
|
|
|
/****** Script for Select command from SSMS ******/
|
|
|
|
|
SELECT [xxx],[xxx]
|
|
|
|
|
FROM [xxx].[xxx].[xxx]
|
|
|
|
|
|
|
|
|
|
2. 查询完毕后,在 Results 中点击左上角空白按钮,全选项目
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/594c0/594c075be297961aea82a4f23fb4987f39436fe6" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
3. 再右键空白按钮,选择 Save Result As...
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/d1380/d138070ff0dadd0c0e7301be010c6626b00e45a1" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
4. 格式可以选择 txt 或者 csv,前者不需要处理,后者要转成 xls
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/bc135/bc13571e9fcac0f6f53abde168c5c20046f2158e" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
转的话,用表格软件打开,然后另存为就行
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/a3a66/a3a660746e5e52bb61d9be577cbb89567a398d9c" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
5. 在新数据库环境下,右键数据库 - 任务 - 导入数据…
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/fc2e8/fc2e87a8ceb14fad6f94cff9219d81b1b775fce3" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
**一定不要复制原表全查询结果,然后直接粘贴!会非常慢,尤其是你远程连接的,2w条数据要三个多小时!**
|
|
|
|
|
|
|
|
|
|
6. 选择数据源里,如果之前导出的是 txt,选择 Flat File Source,如果是转换过的 Excel 文件,选择 Microsoft Excel
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/4dc0f/4dc0f68ca9cf4836ccf6f9b462fc7b120253054d" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
7. 选择目标这里,选择 Microsoft OLE DB Driver for SQL Server,然后重新输入下账号密码
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/3c462/3c4629aee86ce2ac5d03875ce2a373d2b1e42633" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
8. 选择 复制一个或多个表或视图的数据
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/d115e/d115e9d591cad439268a5a481fb33127478e8432" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
9. 目标这里,重新选择下对应的表
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/a0da0/a0da0bbb9a5165c89e11bc900dc44b023f332143" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
10. 检查映射,这里如果有IDE无法转换的类型(比如没有处理得当的日期)就会报错,能自动转换的会显示感叹号,可以进行下一步
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/a8f73/a8f735ae3d1fabe712cc9b569b0c28bac0c836ae" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
11. 立即运行,然后点击 Finish
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/206ef/206efcbf5d23582cbfafbdff0fb078803a62ca7f" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
## 脚本迁移
|
|
|
|
|
|
|
|
|
|
1. 在数据库上右键,Task - Cenerate Scripts... 创建一个脚本
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/a1ac8/a1ac817f25ae7e405a788eefd9e8470577edebd4" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
2. 在 Choose Objects 里,选择一个或多个需要的表,然后下一步
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/d38cb/d38cb156108281dfc2d6d7f3cd0420ec5aabc486" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
3. 这里点击 Advanced
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/e71ca/e71ca3422b43ee513ff90c43fa2b890a106568c7" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
4. 选择到底是要表结构,还是表数据,还是全都要
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/989fb/989fb5a23e2bcf97d6c4900113b65a8aa6d1ed40" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
但是这里坑,每个大版本的 Studio 这里的界面和表述不一样,自己加以理解并选择
|
|
|
|
|
|
|
|
|
|
5. 然后他会生成一个 sql 文件,里面是 sql 文,一条一条的 Insert,拿到新表中执行即可
|
|
|
|
|
|
|
|
|
|
但是如果你的条目太多(根据机器性能决定),一次性执行可能会崩,要分多次执行
|
|
|
|
|
|
|
|
|
|
## 整个数据库迁移,再选择需要的表 Insert
|
|
|
|
|
|
|
|
|
|
1. 首先备份原来的数据库,右键数据库 Tasks - Back Up...
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/ed6c2/ed6c29f250eaf4089f71538a2360e290417ce97c" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
这里要注意你这个数据库名称不能跟目标数据库名称相同,因为后面需要放在一起
|
|
|
|
|
|
|
|
|
|
2. Destination 里 Add... 选择一个本地路径
|
|
|
|
|
|
2025-01-23 16:43:06 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/b3ec9/b3ec91920ecd11b55194b8ebc17233594d3a19d3" alt=""
|
2022-09-25 17:55:41 +08:00
|
|
|
|
|
|
|
|
|
**注意,这里的目录是你服务器所在机器的目录,不是你运行这个数据库 IDE 机器的的目录**
|
|
|
|
|
|
|
|
|
|
3. 目标数据库导入这个数据库后使用 insert 命令导入数据
|
|
|
|
|
|
2022-10-08 14:22:36 +08:00
|
|
|
|
INSERT INTO dbname..sheetname SELECT * FROM dbname..sheetname.
|