分享
 
 
 

C#中使用DTS来导入数据及相关问题

王朝c#·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

向Sql 中导入Excel数据时,使用MS SQL的DTS功能

可以很方便的导入,同时引用Dll文件,可以在程序中对导入过程进行控制。

创建DTS包的过程如下:

1。在SQL企业管理器中,工具菜单选数据转换服务,导入数据

按照它的图形化向导提示,可以一步步创建一个DTS包,可以选择保存在数据库。

2。在SQL企业管理器中,左边树形结构中选择数据转化服务,本地包中

可以新建一个包,同样有图形化的界面建立包:拖一个Excel数据源,拖一个Sql数据源

然后在任务里选 数据转化任务,原数据选Excel源,目的选SQL,然后在转化的肩头上选属性

里面可以配置转化过程。注意带有主键的数据表,要把选项中 启用标示插入去掉

在C#里调用过程如下:

private void RunDTS()

2 {

3 DTS.Package2Class package = new Package2Class();

4 object p = null;

5 package.LoadFromSQLServer("ws-victor-03", null, null, DTS.DTSSQLServerStorageFlags.DTSSQLStgFlag_UseTrustedConnection,

6 null, null, null, "TestDTS", ref p);

7 package.Connections.Item(1).DataSource = "dts.XLS";

8 package.Execute();

9 }

现在项目中遇到问题:

1。插入数据时需要插入时间等Excel数据源中不存在的数据

2。Excel数据源中数据有的需要转化,像数值形,导入后变成了1。23131E12等形式

3。插入数据时需要从Sql中查询数据再插入

现在解决了第一条和第三条的一步分:

在上述配置 数据转化任务 时,

DTSDestination("ICC") = DTSSource("SIM Number");

DTSDestination("IMSI") = DTSSource("IMSI");

DTSDestination("PIN1") = DTSSource("PIN1");

DTSDestination("PUK1") = DTSSource("PUK1");

DTSDestination("PIN2") = DTSSource("PIN2");

DTSDestination("PUK2") = DTSSource("PUK2");

DTSDestination("MSISDN") = DTSSource("MSISDN");

DTSDestination("Fax") = DTSSource("Fax");

DTSDestination("Data") = DTSSource("Data");

DTSDestination("Barring") = DTSSource("Barring");

DTSDestination("MailFormID") = DTSGlobalVariables("MailFromID").Value;

DTSDestination("ReceiveDate") = new Date().getYear() + "-" + new Date().getMonth() + "-" + new Date().getDate();

return(DTSTransformStat_OK);

其中,MailFromID为全局变量,添加方法为包 菜单 属性里面选择全局变量,可在C#中对其进行赋值:

foreach(GlobalVariable global in package.GlobalVariables)

{

if (global.Name == "MailFromID") {

package.GlobalVariables.Remove(global.Name);

}

}

package.GlobalVariables.AddGlobalVariable("MailFromID",MailFromID);

插入时间:

DTSDestination("ReceiveDate") = new Date().getYear() + "-" + new Date().getMonth() + "-" + new Date().getDate();

用javascript拼出来的 哈哈

插入数据时需要从Sql中查询数据再插入:

在包里添加新的任务:

执行Sql任务

SELECT AddressList.*

FROM AddressList

WHERE (ID = ?)

然后配置 输入和输出参数

还剩下第2条没搞定,希望这2天能搞定~

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有