我正在一个学校项目上,人们可以通过在左列中键入单词并在右列中键入翻译来测试自己的知识。此数据必须保存在SQLite数据库中。

因此,例如,用户在左侧的文本框中键入单词:hello,在右侧的文本框中键入bonjour(法语为hello)。然后,我想将数据保存到这样的SQLite数据库中:

编号:1
字:你好
翻译:bonjour

c# - 在SQLite数据库中获取文本框输入有效。但是第二列不起作用。如何解决? (System.Web.UI.WebControls.TextBox)-LMLPHP

我设法使其与以下脚本一起使用:

string veld1 = txtVeld1.Text;
string veld1v2 = txtVeld1v2.Text;
string veld2 = txtVeld2.Text;
string veld2v2 = txtVeld2v2.Text;
string veld3 = txtVeld3.Text;
string veld3v2 = txtVeld3v2.Text;
string veld4 = txtVeld4.Text;
string veld4v2 = txtVeld4v2.Text;
string veld5 = txtVeld5.Text;
string veld5v2 = txtVeld5v2.Text;
string veld6 = txtVeld6.Text;
string veld6v2 = txtVeld6v2.Text;
conn.Open();

cmd.CommandType = System.Data.CommandType.Text;
cmd.Parameters.AddWithValue("@veld1", veld1);
cmd.Parameters.AddWithValue("@veld1v2", txtVeld1v2);
cmd.Parameters.AddWithValue("@veld2", veld2);
cmd.Parameters.AddWithValue("@veld2v2", txtVeld2v2);
cmd.Parameters.AddWithValue("@veld3", veld3);
cmd.Parameters.AddWithValue("@veld3v2", txtVeld3v2);
cmd.Parameters.AddWithValue("@veld4", veld4);
cmd.Parameters.AddWithValue("@veld4v2", txtVeld4v2);
cmd.Parameters.AddWithValue("@veld5", veld5);
cmd.Parameters.AddWithValue("@veld5v2", txtVeld5v2);
cmd.Parameters.AddWithValue("@veld6", veld6);
cmd.Parameters.AddWithValue("@veld6v2", txtVeld6v2);
cmd.CommandText = "INSERT INTO tboverhoren (woord, vertaling) SELECT @veld1 , @veld1v2 UNION ALL SELECT @veld2 , @veld2v2 UNION ALL SELECT @veld3 , @veld3v2 UNION ALL SELECT @veld4 , @veld4v2 UNION ALL SELECT @veld5 , @veld5v2 UNION ALL SELECT @veld6 , @veld6v2";


(我正在使用UNION ALL SELECT语句,因为我想一次插入多行)
但不幸的是,只有第一列确实从文本框中获取输入。第二列仅获得:“ System.Web.UI.WebControls.TextBox”作为数据。

c# - 在SQLite数据库中获取文本框输入有效。但是第二列不起作用。如何解决? (System.Web.UI.WebControls.TextBox)-LMLPHP

我究竟做错了什么?我搜索了STACK溢出,但只发现必须声明Textbox.Text函数,该函数是我在第一列中所做的。我发现其他解决方案不适用于SQLite ...

我真的很感谢您的帮助!

亲切的问候,

埃里亚斯·格鲁特(Elias Groot)

最佳答案

您已经通过访问Text属性从文本框中提取了字符串,例如:

string veld1v2 = txtVeld1v2.Text;


但是,当您实际使用它们时,您可以传递文本框本身,而不是使用声明的变量:

cmd.Parameters.AddWithValue("@veld1v2", txtVeld1v2);


数据框架会发现文本框不是它可以理解的类型,因此在其上调用ToString(),默认情况下会返回类型名称,这就是为什么您在数据库中看到它的原因。

您需要做的就是更改这些行以使用变量:

cmd.Parameters.AddWithValue("@veld1v2", veld1v2); // etc

关于c# - 在SQLite数据库中获取文本框输入有效。但是第二列不起作用。如何解决? (System.Web.UI.WebControls.TextBox),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/43769571/

10-11 02:37
查看更多