Не удается зафиксировать изменения в базе данных SQL Server Compact Edition - PullRequest
0 голосов
/ 08 сентября 2011

У меня проблема,

private void button_Submit_Click(object sender, EventArgs e)
{
   try
   {
      string connectionString = @"Data Source=Database_TouchPOS.sdf;Persist Security Info=False;";
      using (SqlCeConnection connection = new SqlCeConnection(connectionString))
      {
         using (SqlCeCommand command = connection.CreateCommand())
         {
            connection.Open();
            command.CommandText = "INSERT INTO Product (Title,Price,Category_Id) VALUES (@title, @price,@category_Id)";
            command.Parameters.AddWithValue("@title", textBox_Title.Text);
            command.Parameters.AddWithValue("@price", textBox_Price.Text);
            command.Parameters.AddWithValue("@category_Id", comboBox_Category.SelectedIndex);

            command.ExecuteNonQuery();

            MessageBox.Show("Product Added Successfully...");
         }
         connection.Close();
      }                
   }
   catch (SqlException ex)
   {
      MessageBox.Show(ex.Message);
   }
}

Кажется, все в порядке, но все еще не удается добавить данные в базу данных.

  1. Я попытался с полным путем к базе данныхпример c:\project\database.sdf
  2. Я много раз искал, прежде чем спрашивать.Я видел подобные проблемы, но ни одна из них не работает для меня.
  3. Данные добавляются при компиляции, но не фиксируются в базе данных.Я вижу данные после второй попытки отладки.
  4. Пожалуйста, попробуйте подробно объяснить.

Спасибо

Ответы [ 4 ]

1 голос
/ 08 сентября 2011

Возможно, вы сталкиваетесь с этим, http://erikej.blogspot.com/2010/05/faq-why-does-my-changes-not-get-saved.html предлагает вам использовать полный путь к файлу базы данных в строке подключения.

1 голос
/ 12 мая 2014

Это очень старая ветка, поэтому я не знаю, поможет ли она кому-нибудь, если я напишу ответ.

У меня тоже была эта проблема.Когда я выполнял обновление или вставку кода в C #, по-видимому, все было в порядке, но когда я искал базу данных, изменений не было.

Дело в том, что при отладке у меня была открыта база данных в ManagementСтудия.И каким-то образом это препятствовало изменениям базы данных, даже когда не было сообщения об ошибке.Закрытие Management Studio и открытие его после выполнения кода, где изменения полностью сохраняются в базе данных.

С уважением.

1 голос
/ 08 сентября 2011

Вы пытались использовать транзакции явно?

IDbTransaction transaction = connection.BeginTransaction();
//add to database
transaction.Commit(); // before close connection
0 голосов
/ 02 июня 2016

полный пример для тех, кто ищет, как я ... @"Data Source=C:\Users\MYPC\Documents\Visual Studio 2010\Projects\MyProjectFolder\MyProject-1\bin\Debug\MyDatabase.sdf;Persist Security Info=False;";

спасибо за этот пример.Это спасло мой день.

...