关于asp连接DBF数据表报“NOT A TABLE”错误的解决办法

本文介绍使用ASP连接DBF数据表的常见语句及遇到“NOTATABLE”错误的解决方案。通过更改驱动为vfpoledb.dll,可以避免自动增量字段导致的问题,确保数据表的正常读取。

用asp连接DBF数据表,常用以下语句:

dbfpath=server.MapPath("data")   '源目录

set conn=Server.Createobject("adodb.connection")
vStr="Driver={Microsoft Visual FoxPro Driver};SourceType=DBF;SourceDB=" + dbfpath +  ";Exclusive=No;NULL=NO;Collate=Machine;BACKGROUNDFETCH=NO;DELETED=NO"
conn.Open vStr

set rs=conn.execute("select * from 数据表 where idh=300")
……
rs.close
set rs=nothing
如果该表不含自动增量的字段则上述代码没有问题,否则报“NOT A TABLE”错误。到网上查,发现遇到类似问题的例子蛮多的,但都没有很好的解决办法。最后还是DBF表的本家提供了解决方案,即使用vfpoledb.dll这个驱动。连接字符串改为:

vStr="Provider=VFPOLEDB.1;Data Source="+dbfpath+";Collating Sequence=MACHINE" 

使用此驱动前,如果未安装VFP,则需将vfpoledb.dll文件复制到C:\Program Files\Common Files\System\Ole DB\文件夹下,即可支持此驱动。

 

 

用oledb读取dbf文件报错--“外部表不是预期的格式” 我的代码如下 string ole_connstring=String.Empty; ole_connstring = @"Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=dBASE IV;Data Source="+FilePath; OleDbConnection ole_conn = new OleDbConnection(ole_connstring); ole_conn.Open(); string insertsql="Insert into ["+tableName+"] (.......; OleDbCommand da=new OleDbCommand(insertsql,ole_conn); da.ExecuteNonQuery(); DBF版本问题,用VFP9的OLEDB即可 方法一: 进入VFP USE TT COPY TO NEWTT TYPE FOX2X 此方法是把表的文件版本转为新的VFP文件版本解决版本问题。 方法二: 升级JET 引擎到SP8,安装MDAC 2.8,到MS的网站去找 1、VFP9的驱动是最新的,各种版本的DBF均可读出; 2、你的连接字串是用JET的引擎,故要升级JET及MDAC; 3、所需文件在MS的网站均有下载。 方法三: 安装vfpoledb.exe(VFP9的OLEDB),在项目中引用Microsoft OLE DB Provider for FoxPro 7.0 Type Library 1.0,然后使用如下代码: OleDbConnection con = new OleDbConnection("Provider=VFPOLEDB.1;Data Source=D:\\2006工程\\南京建设质量监督站\\资料;Collating Sequence=MACHINE"); con.Open(); DataTable dtQY=new DataTable(); OleDbDataAdapter adapt=new OleDbDataAdapter(); adapt.MissingSchemaAction=MissingSchemaAction.AddWithKey; adapt.SelectCommand = new OleDbCommand("select * from 200512.DBF",con); adapt.Fill(dtQY); adapt.Dispose(); DataView dvQY = dtQY.DefaultView; dtQY.Dispose(); con.Close();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值