导入/导出dBase数据库教程 -电脑资料

从dBase文件中,导入数据到SQL数据库中,很简单,直接用下面的语句:

/*===================================================================*/

--如果接受数据导入的表已经存在

insert into 表 select * from

openrowset('MICROSOFT.JET.OLEDB.4.0'

,'dBase 5.0;DATABASE=c:\','select * from [test.dbf]')

--如果导入数据并生成表

select * into 表 from

openrowset('MICROSOFT.JET.OLEDB.4.0'

,'dBase 5.0;DATABASE=c:\','select * from [test.dbf]')

/*===================================================================*/

--如果从SQL数据库中,导出数据到dBase,如果dBase文件已经存在,就可以简单的用:

insert into

openrowset('MICROSOFT.JET.OLEDB.4.0'

,'dBase 5.0;DATABASE=c:\','select * from [test.dbf]')

select * from 表

/*--说明:

DATABASE=c:\c:\是dbf文件的存放目录

'select * from [test.dbf]test.dbf是指dbf文件名

--*/

--如果dBase文件不存在,就需要用到下面的存储过程了.

/*--数据导出dBase

导出表中的数据到dBase,如果文件不存在,将自动创建文件

基于通用性考虑,仅支持导出标准数据类型

--*/

/*--调用示例

--导出dBase

p_exporttb @tbname='地区资料',@path='c:\',@over=0

--*/

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_exporttb]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)

drop procedure [dbo].[p_exporttb]

GO

create proc p_exporttb

@tbname sysname,--要导出的表名

@path nvarchar(1000),--文件存放目录

@fname nvarchar(250)='',--文件名,默认为表名

@over bit=0--是否覆盖已经存在的文件,如果不覆盖,则直接追加

as

declare @err int,@src nvarchar(255),@desc nvarchar(255),@out int

declare @obj int,@constr nvarchar(1000),@sql varchar(8000),@fdlist varchar(8000)

--参数检测

if isnull(@fname,'')='' set @fname=@tbname+'.dbf'

--检查文件是否已经存在

if right(@path,1)<>'\' set @path=@path+'\'

create table #tb(a bit,b bit,c bit)

set @sql=@path+@fname

insert into #tb exec master..xp_fileexist @sql

if exists(select 1 from #tb where a=1)

if @over=1

begin

set @sql='del '+@sql

exec master..xp_cmdshell @sql,no_output

end

else

set @over=0

else

set @over=1

--数据库创建语句

set @sql=@path+@fname

set @constr='Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties="dBASE 5.0;'

+';HDR=NO;DATABASE='+@path+'"'

--连接数据库

exec @err=sp_oacreate 'adodb.connection',@obj out

if @err<>0 goto lberr

exec @err=sp_oamethod @obj,'open',null,@constr

if @err<>0 goto lberr

--创建表的SQL

select @sql='',@fdlist=''

select @fdlist=@fdlist+','+a.name

,@sql=@sql+',['+a.name+'] '

+case when b.name in('char','nchar','varchar','nvarchar') then

'text('+cast(case when a.length>250 then 250 else a.length end as varchar)+')'

when b.name in('tynyint','int','bigint','tinyint') then 'int'

when b.name in('smalldatetime','datetime') then 'datetime'

when b.name in('money','smallmoney') then 'money'

else b.name end

FROM syscolumns a left join systypes b on a.xtype=b.xusertype

where b.name not in('image','text','uniqueidentifier','sql_variant','ntext','varbinary','binary','timestamp')

and object_id(@tbname)=id

select @sql='create table ['+@fname

+']('+substring(@sql,2,8000)+')'

,@fdlist=substring(@fdlist,2,8000)

if @over=1

begin

exec @err=sp_oamethod @obj,'execute',@out out,@sql

if @err<>0 goto lberr

end

exec @err=sp_oadestroy @obj

set @sql='openrowset(''MICROSOFT.JET.OLEDB.4.0'',''dBase 5.0;DATABASE='

+@path+''',''select * from ['+@fname+']'')'

--导入数据

exec('insert into '+@sql+'('+@fdlist+') select '+@fdlist+' from '+@tbname)

return

lberr:

exec sp_oageterrorinfo 0,@src out,@desc out

lbexit:

select cast(@err as varbinary(4)) as 错误号

,@src as 错误源,@desc as 错误描述

select @sql,@constr,@fdlist

go

/*--数据导出dBase

导出查询语句中的数据到dBase,如果文件不存在,将自动创建文件

基于通用性考虑,仅支持导出标准数据类型

--*/

/*--调用示例

--导出dBase

p_exporttb @sqlstr='select * from 地区资料',@path='c:\',@over=1

--*/

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_exporttb]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)

drop procedure [dbo].[p_exporttb]

GO

create proc p_exporttb

@sqlstr varchar(8000),--要导出的查询名

@path nvarchar(1000),--文件存放目录

@fname nvarchar(250)='temp.dbf',--文件名,默认为temp

@over bit=0--是否覆盖已经存在的文件,如果不覆盖,则直接追加

as

declare @err int,@src nvarchar(255),@desc nvarchar(255),@out int

declare @obj int,@constr nvarchar(1000),@sql varchar(8000),@fdlist varchar(8000)

--参数检测

if isnull(@fname,'')='' set @fname='temp.dbf'

--检查文件是否已经存在

if right(@path,1)<>'\' set @path=@path+'\'

create table #tb(a bit,b bit,c bit)

set @sql=@path+@fname

insert into #tb exec master..xp_fileexist @sql

if exists(select 1 from #tb where a=1)

if @over=1

begin

set @sql='del '+@sql

exec master..xp_cmdshell @sql,no_output

end

else

set @over=0

else

set @over=1

--数据库创建语句

set @sql=@path+@fname

set @constr='Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties="dBASE 5.0;'

+';HDR=NO;DATABASE='+@path+'"'

--创建表的SQL

declare @tbname sysname

set @tbname='##tmp_'+convert(varchar(38),newid())

set @sql='select * into ['+@tbname+'] from('+@sqlstr+') a'

exec(@sql)

--连接数据库

exec @err=sp_oacreate 'adodb.connection',@obj out

if @err<>0 goto lberr

exec @err=sp_oamethod @obj,'open',null,@constr

if @err<>0 goto lberr

--创建表的SQL

select @sql='',@fdlist=''

select @fdlist=@fdlist+','+a.name

,@sql=@sql+',['+a.name+'] '

+case when b.name in('char','nchar','varchar','nvarchar') then

'text('+cast(case when a.length>250 then 250 else a.length end as varchar)+')'

when b.name in('tynyint','int','bigint','tinyint') then 'int'

when b.name in('smalldatetime','datetime') then 'datetime'

when b.name in('money','smallmoney') then 'money'

else b.name end

FROM tempdb..syscolumns a left join tempdb..systypes b on a.xtype=b.xusertype

where b.name not in('image','text','uniqueidentifier','sql_variant','ntext','varbinary','binary','timestamp')

and a.id=(select id from tempdb..sysobjects where name=@tbname)

select @sql='create table ['+@fname

+']('+substring(@sql,2,8000)+')'

,@fdlist=substring(@fdlist,2,8000)

if @over=1

begin

exec @err=sp_oamethod @obj,'execute',@out out,@sql

if @err<>0 goto lberr

end

exec @err=sp_oadestroy @obj

set @sql='openrowset(''MICROSOFT.JET.OLEDB.4.0'',''dBase 5.0;DATABASE='

+@path+'

'',''select * from ['+@fname+']'')'

--导入数据

exec('insert into '+@sql+'('+@fdlist+') select '+@fdlist+' from ['+@tbname+']')

set @sql='drop table ['+@tbname+']'

exec(@sql)

return

lberr:

exec sp_oageterrorinfo 0,@src out,@desc out

lbexit:

select cast(@err as varbinary(4)) as 错误号

,@src as 错误源,@desc as 错误描述

select @sql,@constr,@fdlist

go

相关文章

郑思肖:画菊

《画菊》作者:郑思肖花开不并百花丛,独立疏篱趣未穷。宁可枝头抱香死,何曾吹落北风中。翻译:菊花开放的时候,百花已经凋谢。只有她独自开在稀疏的篱笆旁边,让人心生喜悦,觉得与众不同。更不同的是菊花宁愿保留...
资料大全2012-01-07
郑思肖:画菊

关于精妙同义词

精妙是指非常精彩的意思,以下是小编搜索整理一篇精妙同义词,欢迎大家阅读!精妙同义词: 精湛、精辟、精粹精妙jīng miào[释义] (形)精致巧妙。[构成] 并列式:精+妙例句:1) 在汉代的漆画当...
资料大全2014-05-06
关于精妙同义词

何念庭

何念庭 何念庭(何念庭) 何念庭,女,1983年12月26日出生于台湾,在1999年活的中广流行之星总冠军,2000年7月发行首张个人台语专辑。 目录基本资料 个人概述 个人荣誉 ...
资料大全2013-09-06
何念庭

地球你好吗简谱

黑鸭子合唱组演唱的歌曲。此歌曲是一个以环保为主题,可以提高保护环境的意识。下面是小编整理的相关内容,欢迎大家阅读!  地球你好吗简谱      【拓展】  歌词  当天空不再是蓝色,小鸟不会飞翔。  ...
资料大全2015-08-04
地球你好吗简谱

资产负债表格式

资产负债表格式的怎样的?有哪些注意事项?请查看以下内容,小编为您讲解!篇一:资产负债表的格式资产负债表一般有表首、正表两部分。其中,表首概括地说明报表名称、编制单位、编制日期、报表编号、货币名称、计量...
资料大全2015-04-03
资产负债表格式

情话应该这样说

其实,情话在相恋或是相爱的情侣中,起着调味作用,如果你想说,就应该像下面这样说。1.没什么特别的事, 只想听听你的声音。男人在女人意想不到的情 况下拨个电话温柔地说。2.给我一点时间,我会尽快和她分手...
资料大全2012-07-01
情话应该这样说