如何插入DBF文件(foxpro)

本文关键字:DBF 文件 foxpro 插入 何插入 | 更新日期: 2023-09-27 18:23:52

我在asp.net中有以下代码:

using (OleDbCommand command = dbConnW.CreateCommand())
{
    string CreateTableK = null;
    CreateTableK += "Create Table DSKKAR00 (DSK_ID c(10),DSK_KIND N(1),MON_PYM C(3))";
    OleDbCommand cmdCreateTable = new OleDbCommand(CreateTableK, dbConnW);
    cmdCreateTable.ExecuteNonQuery();
    System.Text.StringBuilder sb = new  System.Text.StringBuilder();
    sb.Append(WorkRoomNo + ","); 
    sb.Append("1,");
    sb.Append(",");
    OleDbCommand cmd3 = new OleDbCommand("Insert into DSKKAR00 (DSK_ID,DSK_KIND,MON_PYM) Values (" + sb.ToString() + ")", dbConnW);
    cmd3.ExecuteNonQuery();

但我有以下错误:

语法错误

如何插入DBF文件(foxpro)

除了Chris提供的功能外,您还将用一个NULL字符串变量启动CREATE TABLE,然后对其执行+=操作。据我所知,NULL++"anystring"将保持为NULL值。。。你可能也会在那里崩溃。

尽管VFP不像其他SQL引擎那样真正适用于SQL注入,但它有进行参数化的好习惯。当您这样做时,使用"?"作为要插入的值的占位符,并按与"?"表示的顺序相同的顺序添加参数。

string CreateTableK = 
   "Create Table DSKKAR00 (DSK_ID c(10),DSK_KIND N(1),MON_PYM C(3))";     
OleDbCommand cmdCreateTable = new OleDbCommand(CreateTableK, dbConnW);
cmdCreateTable.ExecuteNonQuery();     
string MyInsert = 
   "insert into DSKKAR00 ( dsk_id, dsk_kind, mon_pym ) values ( ?, ?, ? )";
OleDbCommand cmd3 = new OleDbCommand( MyInsert, dbConnW);
cmd3.Parameters.AddWithValue( "parmSlot1", WorkRoomNo );
cmd3.Parameters.AddWithValue( "parmSlot2", 1);
cmd3.Parameters.AddWithValue( "parmSlot3", 'tst' ); // or whatever variable to put
cmd3.ExecuteNonQuery(); 

首先,任何时候出现错误时,最好发布整个错误消息。

此外,当试图调试查询问题时,您应该发出发送到服务器/数据库的实际查询并对其进行检查。这样,您可能会发现各种问题,如逗号过多。

说到这里,看看你的代码,你正在连接一个字符串,它看起来确实有太多的逗号。

发出的查询看起来是:

insert into DSKKAR00(DSK_ID, DSK_KIND, MON_PYM) VALUES( X,1, ,)

其中X是WorkRoomNo变量的值。

显然,这不是有效的语法,会导致您看到的错误。逗号表示传递了4个值,但插入查询只标识3列。

下一个问题与列定义本身有关。该表的第一列是c(10);第三个是c(3)。我有点生疏,但那些字符字段不是吗?

如果是这样的话,那么你需要调整你的字符串生成器,在值周围添加适当的引号。。。

这就引出了最后一个问题:不要使用字符串连接来构建查询。使用参数化查询