SQL语句导入导出大全
作者 佚名技术
来源 数据库编程
浏览
发布时间 2012-03-21
it --1为导出,0为导入 as declare @sql varchar(8000) if @tbname like ’%.%.%’ --如果指定了表名,则直接导出单个表 begin set @sql=’bcp ’+@tbname +case when @isout=1 then ’ out ’ else ’ in ’ end +’ "’+@filename+’" /w’ +’ /s ’+@servername +case when isnull(@username,’’)=’’ then ’’ else ’ /u ’+@username end +’ /p ’+isnull(@password,’’) exec master..xp_cmdshell @sql end else begin --导出整个数据库,定义游标,取出所有的用户表 declare @m_tbname varchar(250) if right(@filename,1)<>’\’ set @filename=@filename+’\’ set @m_tbname=’declare #tb cursor for select name from ’+@tbname+’..sysobjects where xtype=’’u’’’ exec(@m_tbname) open #tb fetch next from #tb into @m_tbname while @@fetch_status=0 begin set @sql=’bcp ’+@tbname+’..’+@m_tbname +case when @isout=1 then ’ out ’ else ’ in ’ end +’ "’+@filename+@m_tbname+’.txt " /w’ +’ /s ’+@servername +case when isnull(@username,’’)=’’ then ’’ else ’ /u ’+@username end +’ /p ’+isnull(@password,’’) exec master..xp_cmdshell @sql fetch next from #tb into @m_tbname end close #tb deallocate #tb end go /**********************excel导到txt****************************************/ 想用 select * into opendatasource(...) from opendatasource(...) 实现将一个excel文件内容导入到一个文本文件 假设excel中有两列,第一列为姓名,第二列为很行帐号(16位) 且银行帐号导出到文本文件后分两部分,前8位和后8位分开。 如果要用你上面的语句插入的话,文本文件必须存在,而且有一行:姓名,银行账号1,银行账号2 然后就可以用下面的语句进行插入 注意文件名和目录根据你的实际情况进行修改. insert into opendatasource(’microsoft.jet.oledb.4.0’ ,’text;hdr=yes;database=c:\’ )...[aa#txt] --,aa#txt) --*/ select 姓名,银行账号1=left(银行账号,8),银行账号2=right(银行账号,8) from opendatasource(’microsoft.jet.oledb.4.0’ ,’excel 5.0;hdr=yes;imex=2;database=c:\a.xls’ --,sheet1$) )...[sheet1$] 如果你想直接插入并生成文本文件,就要用bcp declare @sql varchar(8000),@tbname varchar(50) --首先将excel表内容导入到一个全局临时表 select @tbname=’[##temp’+cast(newid() as varchar(40))+’]’ ,@sql=’select 姓名,银行账号1=left(银行账号,8),银行账号2=right(银行账号,8) into ’+@tbname+’ from opendatasource(’’microsoft.jet.oledb.4.0’’ ,’’excel 5.0;hdr=yes;imex=2;database=c:\a.xls’’ )...[sheet1$]’ exec(@sql) --然后用bcp从全局临时表导出到文本文件 set @sql=’bcp "’+@tbname+’" out "c:\aa.txt" /s"(local)" /p"" /c’ exec master..xp_cmdshell @sql --删除临时表 exec(’drop table ’+@tbname) 用bcp将文件导入导出到数据库的存储过程: /*--bcp-二进制文件的导入导出 支持image,text,ntext字段的导入/导出 image适合于二进制文件;text,ntext适合于文本数据文 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
关于SQL语句导入导出大全的所有评论