C#,Winform,将数据插入本地数据库并在DataGridVIew

时间:2016-02-26 11:09:46

标签: c# xml winforms datagridview local-database

我正在制作一个C#Winform,我正在从xml读取一些数据,以及与用户交互。然后我需要将这些数据放入本地数据库,然后通过子表单读取它。

我宣布并阅读数据:

public int score = 0; //not null after user interaction
public string candidate = null; //not null after user interaction
XElement Title = Test.Root.Element("title");
XElement MaxScore = Test.Root.Element("property_maxscore");
XElement PassScore = Test.Root.Element("property_passscore");

(直到这里所有的工作我只是发布它以获得更好的代码理解)

现在我尝试将一些数据插入到本地数据库表中,我使用了两种方法,遗憾的是它们都不适用于我:

首先:

SqlCeConnection con = new SqlCeConnection(@"Data Source=...users.sdf");
con.Open();
SqlCeCommand cmd = new SqlCeCommand(@"INSERT INTO final_tests (test_name, candidate, score, pass_score, max_score, completed) VALUES (@test_name, @candidate, @score, @pass_score, @max_score, @completed)", con);
cmd.Parameters.AddWithValue("test_name", (string) Title);
cmd.Parameters.AddWithValue("candidate", candidate);
cmd.Parameters.AddWithValue("score", score);
cmd.Parameters.AddWithValue("pass_score", (string) PassScore);
cmd.Parameters.AddWithValue("max_score", (string) MaxScore);
cmd.Parameters.AddWithValue("completed", DateTime.Now);
cmd.ExecuteNonQuery();
con.Close();

第二

SqlCeConnection con = new SqlCeConnection(@"Data Source=...users.sdf");
con.Open();
using (SqlCeCommand comm = new SqlCeCommand("SELECT * FROM final_tests WHERE score LIKE @score", con))
{
comm.Parameters.Add(new SqlCeParameter("score", score));
comm.ExecuteNonQuery();
}

我测试了每一行并且它们执行成功,但是当我手动打开数据库时它是空的,当然其他子表单中的DataGridView也是空的。

我尝试了很多修改,但遗憾的是,没有任何修改。我无法找到我的错误所在。如果需要更多信息,我在这里。 完成我的问题: 读取来自xml和用户交互的数据,然后必须将其放入提到的本地数据库中,保存供以后使用,并在其他子表单的DataGridView中显示。谢谢你们 !

2 个答案:

答案 0 :(得分:0)

SqlCeConnection con = new SqlCeConnection(@" Data Source = ... users.sdf");

con.Open();
SqlCeCommand cmd = new SqlCeCommand(@"INSERT INTO final_tests (test_name, candidate, score, pass_score, max_score, completed) VALUES (@test_name, @candidate, @score, @pass_score, @max_score, @completed)", con);
cmd.Parameters.AddWithValue("@test_name", (string) Title);
cmd.Parameters.AddWithValue("@candidate", candidate);
cmd.Parameters.AddWithValue("@score", score);
cmd.Parameters.AddWithValue("@pass_score", (string) PassScore);
cmd.Parameters.AddWithValue("@max_score", (string) MaxScore);
cmd.Parameters.AddWithValue("@completed", DateTime.Now);
int i=cmd.ExecuteNonQuery();


     if(i>0)
    {
         // Success
    }
    con.Close();

第二次更正

SqlCeConnection con = new SqlCeConnection(@"Data Source=...users.sdf");
con.Open();
using (SqlCeCommand comm = new SqlCeCommand("SELECT * FROM final_tests WHERE score LIKE @score", con))
{
comm.Parameters.Add(new SqlCeParameter("score", score));
SsqlDataAdapter aa= new SsqlDataAdapter(Comm);
DataTable dt= new Datatable();
da.Fill(dt);
}

答案 1 :(得分:0)

谢谢大家的帮助和指导!谢谢Tanmay Nehete。你的第一次修正就像一个魅力。

我在列的名称之前添加了@:

cmd.Parameters.AddWithValue("@test_name", (string) Title);

和行:

int i=cmd.ExecuteNonQuery();

并且数据存储在本地数据库中,并显示在所有DataGridViews中,谢谢!