当前位置:Gxlcms > 数据库问题 > 数据库的迁移

数据库的迁移

时间:2021-07-01 10:21:17 帮助过:20人阅读

  • 注册(Register)DAC是根据DACpackage中包含的数据库对象的元数据,在目标SQL Server实例中注册数据库对象。
  • 部署(Deploy)DAC是在目标SQL Server 实例级别上,使用DAC package包含的数据库元数据创建新的DB
  • 升级(Upgrade) DAC是指对现存的数据库元数据进行升级,是DAC作为轻量型的数据库架构迁移工具的特征;
  • 二,迁移数据库架构示例

    1,抽取DAC,打开Extract DAC向导

    选择迁移数据库DAC_Study的架构,右击DAC_Study,打开菜单,一次点击“Tasks”->“Extract Data-tier Application...”,打开Extract DAC向导

    技术分享

    从开始界面(Introduction)可以看出,抽取(Extract)DAC主要分为三步:设置DAC属性,验证和创建Package,需要用户配置的是设置DAC的属性,在抽取DAC package时,必须填写一个唯一的应用程序名(Application name),该属性用于标识DAC。

    技术分享

    2,拆包(unpack)DAC

    unpack DAC 就是拆包,用于打开dacpac文件,查看文件的内容。选中一个dacpac文件,右击弹出“Unpack...”,将拆分文件存放到指定的目标文件夹。

    技术分享

    技术分享

    一个DACPAC文件,供拆解成四个文件,三个XML文件,一个TSQL脚本文件,包含用于创建数据库对象的代码,如图:

    技术分享

    3,注册(Register)DAC

    在目标SQL Server实例上创建一个空的数据库,新的数据库不一定和原来的数据库同名,将新数据库命名为DAC_Test,右击该数据库,一次点击“Tasks”->“Register as Data-tier Application...”,弹出注册(Register)DAC向导

    技术分享

    注册DAC的过程,主要分为三步:设置属性,验证和注册DAC,需要用户配置的是“设置属性”,用户必须填写正确的Application Name,该属性必须和DACPAC文件中的Application Name 相同。

    技术分享

    4,部署(Deploy)DAC

    在一个SQL Server 实例上部署(Deploy)DAC,实际上,是使用DACPAC文件创建新的数据库,实现数据库架构的迁移,和注册DAC不同的时,部署DAC不需要手动创建空的数据库。

    在部署DAC时,右击DataBases,弹出快捷菜单,点击 “Deploy Data-tier Application...”,弹出部署DAC向导,

    技术分享

    部署DAC的过程主要分为四部:选择DACPAC文件,配置部署,Review和部署。根据向导,选择需要部署的dacpack文件,配置新建的数据库名称,在name 属性中输入新的数据库名称,可以和原有的数据库名称不同,查看之后,点击Next,进行部署。部署完成之后,在当前的SQL Server实例中成功创建一个空的数据库。

    技术分享

    技术分享

    4,升级(Upgrade)DAC

    升级(Upgrade)DAC 是对现存数据库的架构(Schema)进行更新和升级,前提是必须有存在数据库,和注册(Register)DAC类似。

    选择升级的数据库,右击弹出快捷菜单,依次点击“Tasks”->“Upgrade Data-tier Application...”,打开升级(Upgrader)DAC向导

    技术分享

    升级DAC的过程十分简单,只需要选择包含最新元数据的dacpac文件,根据向导的提示,直接点击Next就能完成对现存数据库的升级。

    技术分享

    三,从 Backup Package(.bacpac)创建新的数据库

    使用bacpac文件,能够创建一个新的数据库,包含架构(schema)和数据(data),功能类似数据库的还原,都能创建一个新的、包含数据和架构的数据库。

    方法一,使用SSMS向导

    右击Databases,打开“Import Data-tier Application”,打开Wizard,按照UI提示配置即可

    技术分享

    方法二,使用SqlPackage.exe 实现自动导入DAC

    命令的调用示例,为了便于查看,我将命令格式化,在DOS命令行工具中,请不要换行。

    “C:\Program Files (x86)\Microsoft SQL Server\110\DAC\bin\sqlpackage.exe” 
    /a:Import 
    /sf:C:\DataExtraction\Tailspintoys.bacpac 
    /tsn:cgrd7z8kac.database.windows.net 
    /tdn:Tailspintoys 
    /tu:mysysadmin@cgrd7z8kac 
    /tp:Pa55w0rd

    参数解释:

    • sf   – 指定bacpac文件
    • tsn – 指定SQL Server实例名,用于存储新的目标数据库
    • tdn – 指定目标数据库的名称
    • tu   – 指定用于访问SQL Server实例的登录名
    • tp   – 指定用于访问SQL Server实例的登录名对应的密码

    如果使用Windows 验证方式登陆,可以使用ttsc差数代替 tu 和 tp。

    C:\Program Files (x86)\Microsoft SQL Server\130\DAC\bin\SqlPackage.exe 
    -a:Import -sf:C:\TestDAC\dac_name.bacpac -tsn:server_name -tdn:db_name -ttsc:true

    参数:ttsc:{True | False} 指定是否使用Secure Socket Layer (SSL) 加密,以Windows验证方式登录目标SQL Server实例。

     

    参考文档:

    Data-tier Applications

    Export and Import BACPAC using command line

    SqlPackage.exe

    将数据库迁移到SQL Azure的三种工具

    数据库的迁移

    标签:方式   实现   nbsp   std   comm   database   数据库名   sof   功能   

    人气教程排行