表名有没有带空格的。另外,看看引号是否对。 看看这个对你有没有帮助: 以下均以SQL2000、VFP6及以上的表为例 方法一:查询分析器中执行如下语句(先选择对应的数据库)--如果接受导入数据的SQL表已经存在 insert into 已经存在的SQL表名 select * from openrowset('MSDASQL','Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\','select * from aa.DBF')--也可以对应列名进行导入,如: insert into 已经存在的SQL表名 (列名1,列名2...) select (对应列名1,对应列名2...) from openrowset('MSDASQL','Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\','select * from aa.DBF')--如果接受导入数据的SQL表不存在,导入时创建--方法一: select * into 要生成的SQL表名 from openrowset('MSDASQL','Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\','select * from dbf表名.DBF')--方法二: select * INTO TEMP1 from openrowset('VFPOLEDB.1','C:\';'admin';'' ,'select * from dbf表名.DBF') 如果没有安装VFP,需要把vfpoledb.dll拷贝到SYSTEM目录下,并注册。--方法三: select * into 要生成的SQL表名 from OPENROWSET('MICROSOFT.JET.OLEDB.4.0','dBase IV;HDR=NO;IMEX=2;DATABASE=c:\','select * from dbf表名.dbf')--方法四: select * into 要生成的SQL表名 from OPENROWSET('MICROSOFT.JET.OLEDB.4.0','dBase III;HDR=NO;IMEX=2;DATABASE=c:\','select * from dbf表名.dbf')--用前两种方法导入SQL SERVER后,源表再用VFP打开就不提示“不能存取文件”,说明语句执行后就把源表关闭了。不过也有不尽人意的地方,就是用前两种方法导入后,源表中的字符型字段导入后SQL表字段对应变成NVARCHAR了。 --第三种方法有一个缺点:把DBF表导入SQL Server中后,马上用VISUAL FOXPRO打开DBF表,会提示“不能存取文件”,即这个表还被SQL打开着呢。可是过了1分钟左右,再打开DBF表就可以了,说明经过一段时间后查询分析器才把这个表关闭。--也可以只导几个字段 select * into 要生成的SQL表名 from openrowset('MSDASQL','Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\','select 字段1,字段2 from aa.DBF')/*--说明: SourceDB=c:\ c:\是dbf文件的存放目录 aa.DBF 是dbf文件名 --*/
我发现个奇怪的问题,我在查询分析器里修改存储过程,我把动态的导入,改成直接导入 INSERT into gg_cpinfo SELECT * from openrowset ('MSDASQL','Driver=Microsoft Visual FoxPro Driver;SourceType=DBF; SourceDB=E:\TEST\','select * from cpinfo.DBF') ,然后执行,结果,在查询分析器里就抱这个错了: 服务器: 消息 7405,级别 16,状态 1,过程 P_DBF_TO_SQL_1,行 72 异类查询要求为连接设置 ANSI_NULLS 和 ANSI_WARNINGS 选项。这将确保一致的查询语义。请启用这些选项,然后重新发出查询。是不是数据库哪里设置的问题????可是,为什么我第1批导入成功了?
我查了联机丛书,看到这两个选项默认是OFF,于是我也这么想的!
可发现问题依然!
看看这个对你有没有帮助:
以下均以SQL2000、VFP6及以上的表为例
方法一:查询分析器中执行如下语句(先选择对应的数据库)--如果接受导入数据的SQL表已经存在
insert into 已经存在的SQL表名 select * from openrowset('MSDASQL','Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\','select * from aa.DBF')--也可以对应列名进行导入,如:
insert into 已经存在的SQL表名 (列名1,列名2...) select (对应列名1,对应列名2...) from openrowset('MSDASQL','Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\','select * from aa.DBF')--如果接受导入数据的SQL表不存在,导入时创建--方法一:
select * into 要生成的SQL表名 from openrowset('MSDASQL','Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\','select * from dbf表名.DBF')--方法二:
select * INTO TEMP1 from openrowset('VFPOLEDB.1','C:\';'admin';'' ,'select * from dbf表名.DBF')
如果没有安装VFP,需要把vfpoledb.dll拷贝到SYSTEM目录下,并注册。--方法三:
select * into 要生成的SQL表名 from OPENROWSET('MICROSOFT.JET.OLEDB.4.0','dBase IV;HDR=NO;IMEX=2;DATABASE=c:\','select * from dbf表名.dbf')--方法四:
select * into 要生成的SQL表名 from OPENROWSET('MICROSOFT.JET.OLEDB.4.0','dBase III;HDR=NO;IMEX=2;DATABASE=c:\','select * from dbf表名.dbf')--用前两种方法导入SQL SERVER后,源表再用VFP打开就不提示“不能存取文件”,说明语句执行后就把源表关闭了。不过也有不尽人意的地方,就是用前两种方法导入后,源表中的字符型字段导入后SQL表字段对应变成NVARCHAR了。
--第三种方法有一个缺点:把DBF表导入SQL Server中后,马上用VISUAL FOXPRO打开DBF表,会提示“不能存取文件”,即这个表还被SQL打开着呢。可是过了1分钟左右,再打开DBF表就可以了,说明经过一段时间后查询分析器才把这个表关闭。--也可以只导几个字段
select * into 要生成的SQL表名 from openrowset('MSDASQL','Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\','select 字段1,字段2 from aa.DBF')/*--说明:
SourceDB=c:\ c:\是dbf文件的存放目录
aa.DBF 是dbf文件名
--*/
INSERT into gg_cpinfo SELECT * from openrowset
('MSDASQL','Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;
SourceDB=E:\TEST\','select * from cpinfo.DBF')
,然后执行,结果,在查询分析器里就抱这个错了:
服务器: 消息 7405,级别 16,状态 1,过程 P_DBF_TO_SQL_1,行 72
异类查询要求为连接设置 ANSI_NULLS 和 ANSI_WARNINGS 选项。这将确保一致的查询语义。请启用这些选项,然后重新发出查询。是不是数据库哪里设置的问题????可是,为什么我第1批导入成功了?