QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5087|回复: 1
打印 上一主题 下一主题

[分享]SQL SERVER、ACCESS和EXCEL电子表格软件中的数据进行转换

[复制链接]
字体大小: 正常 放大

2

主题

0

听众

19

积分

升级  14.74%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-8-8 14:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
< >熟悉<FONT face="Times New Roman">SQL SERVER 2000</FONT>的数据库管理员都知道,其<FONT face="Times New Roman">DTS</FONT>可以进行数据的导入导出,其实,我们也可以使用<FONT face="Times New Roman">Transact-SQL</FONT>语句进行导入导出操作。在<FONT face="Times New Roman"> Transact-SQL</FONT>语句中,我们主要使用<FONT face="Times New Roman">OpenDataSource</FONT>函数、<FONT face="Times New Roman">OPENROWSET </FONT>函数,关于函数的详细说明,请参考<FONT face="Times New Roman">SQL</FONT>联机帮助。利用下述方法,可以十分容易地实现<FONT face="Times New Roman">SQL SERVER</FONT>、<FONT face="Times New Roman">ACCESS</FONT>、<FONT face="Times New Roman">EXCEL</FONT>数据转换,详细说明如下:<FONT face="Times New Roman"> </FONT></P>
8 T( i& s8 ?1 l* l! L) x0 }3 r< ><FONT face="Times New Roman"> <p></p></FONT></P>  T2 h- ~' O! J. F. d
< ><FONT face="Times New Roman">    </FONT>一、<FONT face="Times New Roman">SQL SERVER </FONT>和<FONT face="Times New Roman">ACCESS</FONT>的数据导入导出</P>" A9 n4 ~% m# H7 y" s' ~; S; z
< ><FONT face="Times New Roman"> <p></p></FONT></P>
4 D" L4 a3 @9 c) i7 U% ?+ a. M< ><FONT face="Times New Roman">    </FONT>常规的数据导入导出:使用<FONT face="Times New Roman">DTS</FONT>向导迁移你的<FONT face="Times New Roman">Access</FONT>数据到<FONT face="Times New Roman">SQL Server</FONT>,你可以使用这些步骤:</P>
; N5 P% N  d. D+ l" N% \< ><FONT face="Times New Roman"> <p></p></FONT></P>& d# [# a5 E( j( v
< ><FONT face="Times New Roman">    1</FONT>在<FONT face="Times New Roman">SQL SERVER</FONT>企业管理器中的<FONT face="Times New Roman">Tools</FONT>(工具)菜单上,选择<FONT face="Times New Roman">Data Transformation</FONT></P>1 _6 G6 L# x  r
< ><FONT face="Times New Roman"> <p></p></FONT></P>
, q  ]1 r9 _, C7 I+ Z< ><FONT face="Times New Roman">    2Services</FONT>(数据转换服务),然后选择<FONT face="Times New Roman"> czdImport Data</FONT>(导入数据)。</P>
; \$ t$ O" t8 C5 g: G< ><FONT face="Times New Roman"> <p></p></FONT></P>, i" z; j( V2 Q
< ><FONT face="Times New Roman">    3</FONT>在<FONT face="Times New Roman">Choose a Data Source</FONT>(选择数据源)对话框中选择<FONT face="Times New Roman">Microsoft Access as the Source</FONT>,然后键入你的。<FONT face="Times New Roman">mdb</FONT>数据库(。<FONT face="Times New Roman">mdb</FONT>文件扩展名)的文件名或通过浏览寻找该文件。</P>
8 q* I5 ]( h. u1 Z# X  T! N9 b0 e< ><FONT face="Times New Roman"> <p></p></FONT></P>4 ~- V: }7 M* Z' T6 b- u- X5 g5 M; d
< ><FONT face="Times New Roman">    4</FONT>在<FONT face="Times New Roman">Choose a Destination</FONT>(选择目标)对话框中,选择<FONT face="Times New Roman">Microsoft OLE</FONT> <FONT face="Times New Roman">DB Prov ider for SQL</FONT> <FONT face="Times New Roman">Server</FONT>,选择数据库服务器,然后单击必要的验证方式。</P>
  l! h! A# r4 G, q) J/ G< ><FONT face="Times New Roman"> <p></p></FONT></P>6 c2 K0 S3 |# Z( b/ r, Z# j: F! `$ E
< ><FONT face="Times New Roman">    5</FONT>在<FONT face="Times New Roman">Specify Table Copy</FONT>(指定表格复制)或<FONT face="Times New Roman">Query</FONT>(查询)对话框中,单击<FONT face="Times New Roman">Copy tables</FONT>(复制表格)。</P>, E: F* b" @8 x! l/ ~. T
< ><FONT face="Times New Roman"> <p></p></FONT></P>
6 d* b0 I# C( B( R< ><FONT face="Times New Roman">    6</FONT>在<FONT face="Times New Roman">Select Source Tables</FONT>(选择源表格)对话框中,单击<FONT face="Times New Roman">Select All</FONT>(全部选定)。下一步,完成。</P>8 Q$ |& I* ~& A% N
< ><FONT face="Times New Roman"> <p></p></FONT></P>
( u, _5 c$ r' G. Z* {< ><FONT face="Times New Roman">    Transact-SQL</FONT>语句进行导入导出:</P>* y6 [2 Z" |3 V& G' f& T
< ><FONT face="Times New Roman"> <p></p></FONT></P>/ H8 R, B7 o  D# \( L6 t
< ><FONT face="Times New Roman">    1.</FONT>在<FONT face="Times New Roman">SQL SERVER</FONT>里查询<FONT face="Times New Roman">access</FONT>数据:</P>8 t4 t9 @6 W* \* Y" ^9 X7 J" i
< ><FONT face="Times New Roman"> <p></p></FONT></P>
; J' Z' X* C. [" ]& e8 X< ><FONT face="Times New Roman">    SELECT * FROM OpenDataSource</FONT>(<FONT face="Times New Roman"> \\\'Microsoft.Jet.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman">\\\'Data Source="c</FONT>:<FONT face="Times New Roman">\\\\DB.mdb"</FONT>;<FONT face="Times New Roman">User ID=Admin</FONT>;<FONT face="Times New Roman">assword=\\\'</FONT>)……表名</P>* X9 c# v" E3 P  a' c" n6 m( \
< ><FONT face="Times New Roman"> <p></p></FONT></P># k, j; T) d8 Q' i
< ><FONT face="Times New Roman">    2.</FONT>将<FONT face="Times New Roman">access</FONT>导入<FONT face="Times New Roman">SQL server</FONT>在<FONT face="Times New Roman">SQL SERVER </FONT>里运行:</P>
( k( M& L( q3 ]- n2 X< ><FONT face="Times New Roman"> <p></p></FONT></P>
7 y1 z* d$ T6 v/ E( f) h< ><FONT face="Times New Roman">SELECT * INTO newtable FROM OPENDATASOURCE </FONT>(<FONT face="Times New Roman">\\\'Microsoft.Jet.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman">\\\'Data Source="c</FONT>:<FONT face="Times New Roman">\\\\DB.mdb"</FONT>;<FONT face="Times New Roman">User ID=Admin</FONT>;<FONT face="Times New Roman">assword=\\\' </FONT>)……表名<FONT face="Times New Roman"> </FONT></P>) K- I  b. b: B; H7 O7 k
< ><FONT face="Times New Roman"> <p></p></FONT></P>, h  m' V( _/ \( g( p" C; O
<P ><FONT face="Times New Roman">    3.</FONT>将<FONT face="Times New Roman">SQL SERVER</FONT>表里的数据插入到<FONT face="Times New Roman">Access</FONT>表中在<FONT face="Times New Roman">SQL SERVER </FONT>里运行:</P>
, T" y# K' b. {9 L<P ><FONT face="Times New Roman"> <p></p></FONT></P>& |- q7 Z6 ]! p9 [  d7 L
<P ><FONT face="Times New Roman">insert into OpenDataSource</FONT>(<FONT face="Times New Roman"> \\\'Microsoft.Jet.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman">\\\'Data Source=" c</FONT>:<FONT face="Times New Roman">\\\\DB.mdb"</FONT>;<FONT face="Times New Roman">User ID=Admin</FONT>;<FONT face="Times New Roman">Password=\\\'</FONT>)……表名<FONT face="Times New Roman"> </FONT>(列名<FONT face="Times New Roman">1</FONT>,列名<FONT face="Times New Roman">2</FONT>)<FONT face="Times New Roman"> select </FONT>列名<FONT face="Times New Roman">1</FONT>,列名<FONT face="Times New Roman">2 from sql</FONT>表<FONT face="Times New Roman"> </FONT></P>
" v9 W$ p3 i  }5 h0 v# G<P ><FONT face="Times New Roman"> <p></p></FONT></P>, o/ z. K3 V! Z8 \
<P ><FONT face="Times New Roman">    </FONT>实例:<FONT face="Times New Roman">insert into OPENROWSET</FONT>(<FONT face="Times New Roman">\\\'Microsoft.Jet.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman">\\\'C</FONT>:<FONT face="Times New Roman">\\\\db.mdb\\\'</FONT>;<FONT face="Times New Roman">\\\'admin\\\'</FONT>;<FONT face="Times New Roman">\\\'\\\'</FONT>,<FONT face="Times New Roman"> Test</FONT>)<FONT face="Times New Roman"> select id</FONT>,<FONT face="Times New Roman">name from Test</FONT></P>
/ d. a/ ]7 ^/ g! b<P ><FONT face="Times New Roman"> <p></p></FONT></P>8 h5 p" Q2 r& Z1 R% `# e) ^6 `
<P ><FONT face="Times New Roman">    INSERT INTO OPENROWSET</FONT>(<FONT face="Times New Roman">\\\'Microsoft.Jet.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman"> \\\'c</FONT>:<FONT face="Times New Roman">\\\\trade.mdb\\\'</FONT>;<FONT face="Times New Roman"> \\\'admin\\\'</FONT>;<FONT face="Times New Roman"> \\\'\\\'</FONT>,<FONT face="Times New Roman"> </FONT>表名)<FONT face="Times New Roman"> SELECT * FROM sqltablename</FONT></P>
: t/ O7 F9 o( j2 `8 z* {<P ><FONT face="Times New Roman"> <p></p></FONT></P>: p& P- z, X0 t* w
<P ><FONT face="Times New Roman">    </FONT>二、<FONT face="Times New Roman">SQL SERVER </FONT>和<FONT face="Times New Roman">EXCEL</FONT>的数据导入导出</P>
+ Q% w- j  |. p<P ><FONT face="Times New Roman"> <p></p></FONT></P>
8 q4 }# ^" X5 @6 C+ @6 I<P ><FONT face="Times New Roman">    1</FONT>、在<FONT face="Times New Roman">SQL SERVER</FONT>里查询<FONT face="Times New Roman">Excel</FONT>数据:</P>9 H; A5 e8 g8 [3 w; W
<P ><FONT face="Times New Roman"> <p></p></FONT></P>& ]& P& f  B' D2 C& P
<P ><FONT face="Times New Roman">    SELECT * FROM OpenDataSource</FONT>(<FONT face="Times New Roman"> \\\'Microsoft.Jet.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman">\\\'Data Source="c</FONT>:<FONT face="Times New Roman">\\\\book1.xls"</FONT>;<FONT face="Times New Roman">User ID=Admin</FONT>;<FONT face="Times New Roman">Password=</FONT>;<FONT face="Times New Roman">Extended properties=Excel 5.0\\\'</FONT>)……<FONT face="Times New Roman">[Sheet1$] </FONT></P>
: C" S: X' U6 k/ [<P ><FONT face="Times New Roman"> <p></p></FONT></P>
( d1 G! y" Y# [& }, s1 e<P ><FONT face="Times New Roman">    </FONT>下面是个查询的示例,它通过用于<FONT face="Times New Roman"> Jet </FONT>的<FONT face="Times New Roman"> OLE DB </FONT>提供程序查询<FONT face="Times New Roman"> Excel </FONT>电子表格。</P>
0 e  y- G% y3 o0 X<P ><FONT face="Times New Roman"> <p></p></FONT></P>
$ h8 K; k' S. Z8 p7 L* F0 y* J<P ><FONT face="Times New Roman">    SELECT * FROM OpenDataSource </FONT>(<FONT face="Times New Roman"> \\\'Microsoft.Jet.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman">\\\'Data Source="c</FONT>:<FONT face="Times New Roman">\\\\Finance\\\\account.xls"</FONT>;<FONT face="Times New Roman">User ID=Admin</FONT>;<FONT face="Times New Roman">Password=</FONT>;<FONT face="Times New Roman">Extended properties=Excel 5.0\\\'</FONT>)……<FONT face="Times New Roman">xactions</FONT></P>$ q) {6 F9 C  u9 M7 k' p$ \
<P ><FONT face="Times New Roman"> <p></p></FONT></P>! B" G9 \3 i. E' P+ r
<P ><FONT face="Times New Roman">    2</FONT>、将<FONT face="Times New Roman">Excel</FONT>的数据导入<FONT face="Times New Roman">SQL server </FONT>:</P>/ P5 x/ P) F" c9 `* L8 x
<P ><FONT face="Times New Roman"> <p></p></FONT></P>
4 \/ i. t7 z/ a<P ><FONT face="Times New Roman">    SELECT * into newtable FROM OpenDataSource</FONT>(<FONT face="Times New Roman"> \\\'Microsoft.Jet.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman">\\\'Data Source="c</FONT>:<FONT face="Times New Roman">\\\\book1.xls"</FONT>;<FONT face="Times New Roman">User ID=Admin</FONT>;<FONT face="Times New Roman">Password=</FONT>;<FONT face="Times New Roman">Extended properties=Excel 5.0\\\'</FONT>)……<FONT face="Times New Roman">[Sheet1$] </FONT></P>! Y0 }$ U+ f+ L
<P ><FONT face="Times New Roman"> <p></p></FONT></P>
# S# T& Z2 @, ]1 a4 j<P ><FONT face="Times New Roman">    </FONT>实例:<FONT face="Times New Roman">SELECT * into newtable FROM OpenDataSource</FONT>(<FONT face="Times New Roman"> \\\'Microsoft.Jet.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman">\\\'Data Source="c</FONT>:<FONT face="Times New Roman">\\\\Finance\\\\account.xls"</FONT>;<FONT face="Times New Roman">User ID=Admin</FONT>;<FONT face="Times New Roman">Password=</FONT>;<FONT face="Times New Roman">Extended properties=Excel 5.0\\\'</FONT>)……<FONT face="Times New Roman">xactions</FONT></P>
/ }( ^% E  X7 F& L! B<P ><FONT face="Times New Roman"> <p></p></FONT></P>5 S- {. _2 m  T: X  n% V
<P ><FONT face="Times New Roman">    3</FONT>、将<FONT face="Times New Roman">SQL SERVER</FONT>中查询到的数据导成一个<FONT face="Times New Roman">Excel</FONT>文件<FONT face="Times New Roman">T-SQL</FONT>代码:</P>
& d+ x5 S1 w# @% F<P ><FONT face="Times New Roman"> <p></p></FONT></P>
- t5 A/ o( E* I% R" s& x5 e<P ><FONT face="Times New Roman">    EXEC master</FONT>……<FONT face="Times New Roman">xp_cmdshell \\\'bcp </FONT>库名。<FONT face="Times New Roman">dbo.</FONT>表名<FONT face="Times New Roman">out c</FONT>:<FONT face="Times New Roman">\\\\Temp.xls -c -q -S"servername" -U"sa" -P""\\\'</FONT>参数:<FONT face="Times New Roman">S </FONT>是<FONT face="Times New Roman">SQL</FONT>服务器名;<FONT face="Times New Roman">U</FONT>是用户;<FONT face="Times New Roman">P</FONT>是密码说明:还可以导出文本文件等多种格式<FONT face="Times New Roman"> </FONT></P>
9 P- {( J- j2 h1 I7 |<P ><FONT face="Times New Roman"> <p></p></FONT></P>
, e' p% t: }7 q& h! T- j<P ><FONT face="Times New Roman">    </FONT>实例:<FONT face="Times New Roman">EXEC master</FONT>……<FONT face="Times New Roman">xp_cmdshell \\\'bcp saletesttmp.dbo.CusAccount out c</FONT>:<FONT face="Times New Roman">\\\\temp1.xls -c -q -S"pmserver" -U"sa" -P"sa"\\\' </FONT></P>' {# ?4 c3 g' d0 b% ]2 E2 a9 P3 ?
<P ><FONT face="Times New Roman"> <p></p></FONT></P>
) ~* t' S$ j: o8 p  [9 u6 F<P ><FONT face="Times New Roman">    EXEC master</FONT>……<FONT face="Times New Roman">xp_cmdshell \\\'bcp "SELECT au_fname</FONT>,<FONT face="Times New Roman"> au_lname FROM pubs</FONT>……<FONT face="Times New Roman">authors ORDER BY au_lname" queryout C</FONT>:<FONT face="Times New Roman">\\\\ authors.xls -c -Sservername -Usa -Ppassword\\\'</FONT></P>6 t* ]5 d8 f* N
<P ><FONT face="Times New Roman"> <p></p></FONT></P>
( U+ C( y. A4 Y, H<P ><FONT face="Times New Roman">    </FONT>在<FONT face="Times New Roman">VB6</FONT>中应用<FONT face="Times New Roman">ADO</FONT>导出<FONT face="Times New Roman">EXCEL</FONT>文件代码:<FONT face="Times New Roman">Dim cn As New ADODB.Connection cn.open "Driver={SQL Server}</FONT>;<FONT face="Times New Roman">Server=WEBSVR</FONT>;<FONT face="Times New Roman">DataBase=WebMis</FONT>;<FONT face="Times New Roman">UID=sa</FONT>;<FONT face="Times New Roman">WD=123</FONT>;<FONT face="Times New Roman">" cn.execute "master</FONT>……<FONT face="Times New Roman">xp_cmdshell \\\'bcp "SELECT col1</FONT>,<FONT face="Times New Roman"> col2 FROM </FONT>库名。<FONT face="Times New Roman">dbo.</FONT>表名<FONT face="Times New Roman">" queryout E</FONT>:<FONT face="Times New Roman">\\\\DT.xls -c -Sservername -Usa -Ppassword\\\'" </FONT></P>
% g& c# L8 e! A4 Y6 o# k, ?" q2 @# O<P ><FONT face="Times New Roman"> <p></p></FONT></P>2 t  d- P! G( h; V* S
<P ><FONT face="Times New Roman">    4</FONT>、在<FONT face="Times New Roman">SQL SERVER</FONT>里往<FONT face="Times New Roman">Excel</FONT>插入数据:</P>
) l, j* e7 o4 l" e) K$ d& e<P ><FONT face="Times New Roman"> <p></p></FONT></P>
" }. J, k% W. [) r) o' B- G/ o<P ><FONT face="Times New Roman">    insert into OpenDataSource</FONT>(<FONT face="Times New Roman"> \\\'Microsoft.Jet.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman">\\\'Data Source="c</FONT>:<FONT face="Times New Roman">\\\\Temp.xls"</FONT>;<FONT face="Times New Roman">User ID=Admin</FONT>;<FONT face="Times New Roman">Password=</FONT>;<FONT face="Times New Roman">Extended properties=Excel 5.0\\\'</FONT>)……<FONT face="Times New Roman">table1 </FONT>(<FONT face="Times New Roman">A1</FONT>,<FONT face="Times New Roman">A2</FONT>,<FONT face="Times New Roman">A3</FONT>)<FONT face="Times New Roman"> values </FONT>(<FONT face="Times New Roman">1</FONT>,<FONT face="Times New Roman">2</FONT>,<FONT face="Times New Roman">3</FONT>)<FONT face="Times New Roman"> </FONT></P>
) [9 W; g( y2 ^: X<P ><FONT face="Times New Roman"> <p></p></FONT></P>
2 L) Y1 ?- G8 _/ [+ `<P ><FONT face="Times New Roman">    T-SQL</FONT>代码:<FONT face="Times New Roman">INSERT INTO OPENDATASOURCE</FONT>(<FONT face="Times New Roman">\\\'Microsoft.JET.OLEDB.4.0\\\'</FONT>,<FONT face="Times New Roman">\\\'Extended Properties=Excel 8.0</FONT>;<FONT face="Times New Roman">Data source=C</FONT>:<FONT face="Times New Roman">\\\\training\\\\inventur.xls\\\'</FONT>)……<FONT face="Times New Roman">[Filiale1$] </FONT>(<FONT face="Times New Roman">bestand</FONT>,<FONT face="Times New Roman"> produkt</FONT>)<FONT face="Times New Roman"> VALUES </FONT>(<FONT face="Times New Roman">20</FONT>,<FONT face="Times New Roman"> \\\'Test\\\'</FONT>)</P>
2 e" ~1 t3 r9 j4 o+ d, X) n: B  W<P ><FONT face="Times New Roman"> <p></p></FONT></P>1 ~9 I- }- @3 g
<P ><FONT face="Times New Roman">    </FONT>总结:利用以上语句,我们可以方便地将<FONT face="Times New Roman">SQL SERVER</FONT>、<FONT face="Times New Roman">ACCESS</FONT>和<FONT face="Times New Roman">EXCEL</FONT>电子表格软件中的数据进行转换,为我们提供了极大方便!</P>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
lzh0601        

2

主题

3

听众

89

积分

升级  88.42%

该用户从未签到

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-6-11 08:54 , Processed in 0.314875 second(s), 63 queries .

回顶部