Как избежать дубликатов в удаленной БД при синхронизации с локальной базой данных в C # - PullRequest
0 голосов
/ 22 ноября 2018

Я попробовал код и не удалось из-за дублирования строк в удаленной базе данных при вставке из локальной базы данных.

using System.Data.SQLite;
using System.Net.NetworkInformation;
using MySql.Data.MySqlClient;
namespace super
{
public partial class neworupload : Form
{
     SQLiteConnection con = new SQLiteConnection(@"connection string");
     MySqlConnection conn;
     String connstring;
     public neworupload()
     {
          InitializeComponent();
     }
     private void button1_Click(object sender, EventArgs e)
     {
          bool connection = NetworkInterface.GetIsNetworkAvailable();
          if (connection == true)
          {
               connstring = "SERVER=your ip;PORT=port;DATABASE=dbname;UID=userid;PASSWORD=password;SslMode = none;";
               try
               {
                    con.Open();
                    MessageBox.Show("Connection success");
                    String qu = "select * from users ";
                    SQLiteCommand cmd = new SQLiteCommand(qu, con);
                    SQLiteDataReader data = cmd.ExecuteReader();
                    while (data.Read())
                    {
                         String a = data["iduser"].ToString();
                         String b = data["name"].ToString();
                         String c = data["type"].ToString();
                         String d = data["email"].ToString();
                         String f = data["hash"].ToString();
                         Console.WriteLine(a);
                         Console.WriteLine(b);
                         Console.WriteLine(c);
                         Console.WriteLine(d);
                         Console.WriteLine(f);
                         conn = new MySqlConnection();
                         conn.ConnectionString = connstring;
                         conn.Open();
                         String qudemo = "select iduser from users";
                         Console.WriteLine("dddd" + qudemo);
                         String qu1 = "INSERT INTO users(iduser,name,type,email,hash) Values(@iduser,@name,@type,@email,@hash)";
                         MySqlCommand cmd1 = new MySqlCommand(qu1, conn);
                         cmd1.Parameters.AddWithValue("@iduser", a);
                         cmd1.Parameters.AddWithValue("@name", b);
                         cmd1.Parameters.AddWithValue("@type", c);
                         cmd1.Parameters.AddWithValue("@email", d);
                         cmd1.Parameters.AddWithValue("@hash", f);
                         cmd1.ExecuteNonQuery();
                         conn.Close();
                   }
                   con.Close();
               }
               catch (MySql.Data.MySqlClient.MySqlException ex)
               {
                   Console.WriteLine(ex);
               }
           }
           else
           {
                MessageBox.Show("Check connectivity and try again!");
           }
       }
   }
}

Здесь локальная база данных содержит 7 строк, а удаленная база данных содержит 5 строк.Первые 5 строк в локальной и удаленной базе данных совпадают.Так что пока мы вставляли запрос не удалось с дублированием строк.На самом деле дополнительные 2 строки должны быть вставлены в удаленную базу данных.Как избежать этой проблемы?

1 Ответ

0 голосов
/ 22 ноября 2018

Сохраните последний сохраненный идентификатор пользователя в локальном БД, а когда вы снова перейдете на удаленный БД для синхронизации ваших данных, добавьте предложение where в ваш запрос где RemoteDB.UserID> local.LastStoredUserID .Так что он будет только получать новые записи ...

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...