SQL Server中使用DTS设计器进行数据转移

作者:xiaoqiao 时间:2009-01-08 16:15:00 

以SQL Server中的Northwind示范数据库为例,利用DTS设计器,进行数据的转移。

转移任务的步骤:

◆1. 新建目的数据库NOrthwind_DTS

◆2. 激活DTS设计器

在Enterprise Manager上右击数据转换服务图表->新建包,将弹出一个新的窗口。

◆3. 创建数据源与目的地

在第2步弹出的新窗口右侧工具栏中找到Microsoft OLE DB Provider for SQL Server图标,单击,并在弹出的对话框的新建链接栏输入Northwind,在数据库(B)的下拉列表中选取Northwind选项。其他默认设置,确定。然后,以同样的方法创建数据目的地,命名为Northwind_WH,其中数据库(B)下拉列表选项中选取 Northwind_WH选项。

◆4. 转移事实表

首先创建转换数据任务:先单击Northwind图标,然后按住ctrl键再单击Northwind_WH图标,即同时选中第3步创建出来的Northwind图标和Northwind_WH图标,然后在工具栏上找到“转换数据任务”工具按钮,单击即可以创建一个从Northwind数据源指向Northwind_WH数据目的地的指针,我们可以新建一个批注文本框,为这个指针命名“Sales事实表转换数据任务”。

设置数据转换任务:双击Sales事实表的转换数据任务指针,在弹出的属性对话框中单击【源】标签,在【描述(D):】中输入“Sales事实表转换数据任务”,然后选中【SQL查询(S):】单选按钮,并输入一下语句:

select e.EmployeeID, p.ProductID, s.SupplierID,

c.CustomerID, o.OrderDate, od.UnitPrice,

Od.Quantity, od.Discount

from Orders o,[Order Details] od, Employees e,

Products p, Suppliers s, Customers c

where (o.OrderID = od.OrderID) and

(o.EmployeeID = e.EmployeeID) and

(o.CustomerID = c.CustomerID) and

(od.ProductId = p.ProductID) and

(p.SupplierID = s.SupplierID);

我们可以点击“分析查询”按钮,检查SQL语句的语法是否正确;也可以“预览”查询结果,以检验数据是否正确;单击“生成查询”即可激活查询设计器,根据需要对刚才的SQL语句进行修改。

单击【目的】标签,然后单击“创建”按钮,即可激活一个包含SQL的对话框,我们将语句中的“新建表”修改成我们需要的表名“Sales”,并在最后添加一行:[Total] money NOT NULL。这时,DTS设计器已经为我们在Northwind_WH数据中新建了表Sales。

单击【转换】标签,可以看到DTS设计器为我们指定的字段之间的转换任务。我们希望将UnitPrice*(1.0-Discount)*Quantity存入Total字段,因此这里只需要对Total字段进行如下设置:

现在左侧的“源”中选中Quantity、UnitPrice和Discount,然后选中右侧“目的”的Total,选中之后,单击“新建”按钮,在弹出的对话框中选中ActiveX Script,点确定,将弹出转换属性对话框,点击此对话框中的“属性”按钮,激活“ActiveX脚本转换属性窗口,然后在此窗口的左侧“语言(L):”下拉列表中选中VB Script Language,修改右侧的代码如下:

Function Main()

DTSDestination("Total") =

DTSSource("UnitPrice")*DTSSource("Quantity")*(1.0-DTSSource("Discount"))

Main = DTSTransformStat_OK

End Function

在这里也可以点击“分析”按钮,以检查转换函数是否正确书写。也可以“测试”并在测试中“查看结果”。最后,一路确定返回到“转换数据任务属性”对话框。

确定并完成设置,回到第一步的主窗口。

◆5.保存DTS转换数据任务包,在保存的时候可以对此转换数据任务做一些相应的设置。

◆6.执行包。与数据转换相关的信息都存储在包之内,我们可以在适当时间执行包以将数据加载进目标数据库。包可以重复使用,可以包含一个以上的表转换任务。如果希望每个一段时间后保能够递增式的将数据加载,则可以将时间或是其他的条件一并加入包内。

现在我们来执行刚才建立好的包,将数据从Northwind加载到Northwind_WH。在转换数据任务下面的本地包目录中找到刚才建立好的包的图标,右键选取【执行包(X)】选项,按提示操作即可。

标签:
0
投稿

猜你喜欢

  • Golang 正则匹配效率详解

    2024-01-30 03:41:47
  • Django数据库(SQlite)基本入门使用教程

    2024-01-22 01:13:03
  • Python基于wordcloud及jieba实现中国地图词云图

    2021-03-31 15:08:53
  • Golang的strings.Split()踩坑记录

    2024-02-22 11:34:05
  • python单线程文件传输的实例(C/S)

    2023-04-07 22:45:48
  • Python德劳内三角剖分详解

    2021-02-18 23:08:49
  • opencv实现图像旋转效果

    2023-07-17 13:28:40
  • python遍历类中所有成员的方法

    2022-11-16 22:29:00
  • firefox扩展插件制作方法

    2007-10-12 13:50:00
  • Python类中的魔法方法之 __slots__原理解析

    2023-10-01 18:49:51
  • ext3下删除mysql数据库的数据恢复案例

    2009-05-13 14:39:00
  • python中@property和property函数常见使用方法示例

    2021-11-13 03:32:20
  • Django 创建新App及其常用命令的实现方法

    2023-05-20 09:04:47
  • 在Python下进行UDP网络编程的教程

    2021-10-16 08:08:20
  • 阿里云CentOS7搭建Apache+PHP+MySQL环境

    2023-11-23 02:44:59
  • 关于python变量的引用以及在底层存储原理

    2021-06-24 07:37:35
  • oracle中存储函数与存储过程的区别介绍

    2023-07-12 23:40:15
  • c# 获取数据库中所有表名称的方法

    2024-01-16 18:41:33
  • 搭建一个开源项目两种方式安装git的详细教程

    2022-10-24 13:04:55
  • 在Pycharm中安装Pandas库方法(简单易懂)

    2023-07-21 19:26:28
  • asp之家 网络编程 m.aspxhome.com