2

我有一个名为 ID 的文本框和一个保存按钮。单击保存按钮后,我想简单地将我在文本框中写入的任何内容存储在 SQLite 数据库文件中。

代码正在编译,程序运行没有任何错误,但我没有看到我在同一应用程序下创建的数据库文件 (file1.db) 中保存的任何记录。

namespace WindowsFormsApplication1
{
public partial class Form1 : Form
{
    private SQLiteConnection sqlcon;
    private SQLiteCommand sqlcmd;
    private SQLiteDataAdapter dataBase;
    private DataSet dataSet = new DataSet();
    private DataTable dataTable = new DataTable();


    public Form1()
    {
        InitializeComponent();
    }

    private void createDataBase()
    {
       dataBase = new SQLiteDataAdapter();
    }

    private void ExecuteQuery(string txtQuery)
    {            
     using (SQLiteConnection sqlcon = new SQLiteConnection("Data Source=file1.db"))
     {
            using (SQLiteCommand sqlcmd = sqlcon.CreateCommand())
            {
                sqlcon.Open();
                sqlcmd.CommandText = txtQuery;
                sqlcmd.ExecuteNonQuery();
            }
        }
    }

    private void createDataTable()
    {
        dataTable = new DataTable();
        string txtQuery1 = "CREATE TABLE RECORDS ( ID varchar(255))";
        ExecuteQuery(txtQuery1);
    }

    private void button1_Click(object sender, EventArgs e)
    {
        string txtQuery2 = "INSERT INTO RECORDS (ID) VALUES ('" + textBox1.Text + "')";
        ExecuteQuery(txtQuery2);
    }
4

2 回答 2

2

几件事。

首先,我看不到您实际上将查询传递给您的ExecuteQuery方法的位置。您需要修改您的按钮单击方法,如下所示:

protected void button1_Click(object sender, EventArgs e)
{
  string txtQuery = "INSERT INTO RECORDS ID VALUES  ('" + textBox1.Text + "')";
  ExecuteQuery(txtQuery);
}

其次,查询本身看起来很奇怪。通常结构类似于

INSERT INTO RECORDS(ID) VALUES('myvalue')

您是否尝试过直接执行它?

最后,我强烈建议你重写它并摆脱你的全局连接和命令变量。除了不好的做法之外,您所拥有的可能会泄漏内存并通常会导致其他问题。任何实现 IDisposable 的东西,例如 SQLiteConnection 和 SQLiteCommand 都应该包含在 using 子句中。例如:

using (SQLiteConnection conn = new SQLiteConnection("conn string")) {
  using (SQLiteCommand cmd = conn.CreateCommand()) {
    sqlcmd.CommandText = txtQuery;
    sqlcmd.ExecuteNonQuery();    
  }
}

这将在每个查询运行后自动清理。此外,由于连接池,它就像您使用全局变量来缓存它们一样快。最后,如果发生错误,您不必担心内存泄漏。

于 2012-06-20T23:12:52.690 回答
1

您没有执行查询。尝试这个:

private void button1_Click(object sender, EventArgs e)
{
  string txtQuery = "INSERT INTO RECORDS ID VALUES    ('" + textBox1.Text + "')";  
  ExecuteQuery(txtQuery);
}
于 2012-06-20T23:13:20.143 回答