gpt4 book ai didi

c# - 如何插入 DBF 文件 (foxpro)

转载 作者:太空狗 更新时间:2023-10-29 22:27:50 26 4
gpt4 key购买 nike

我在 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();

但是我有以下错误:

Syntax error

最佳答案

除了 Chris 提供的内容之外,您还使用 NULL 字符串变量开始创建 TABLE,然后对其执行 +=。据我所知, NULL += "anystring"将保持空值......你可能也会在那里崩溃。

虽然 VFP 并不像其他 SQL 引擎那样真正容易受到 SQL 注入(inject)的影响,但它的好习惯是进行参数化。当你这样做时,使用“?”作为要插入的值的占位符,并按照与“?”相同的顺序添加参数代表。

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();

关于c# - 如何插入 DBF 文件 (foxpro),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9198197/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com