Как проверить, существует ли уже значение в базе данных в Android - PullRequest
3 голосов
/ 19 октября 2011

У меня есть база данных, в которую я буду добавлять элементы после анализа ответа JSON.Как я могу проверить, присутствуют ли значения в базе данных, и предотвратить повторную вставку?

Например.Имя базы данных: Exicom.sqlite

Имя таблицы: TimeReport

Поля в базе данных: userID, clientName

Я использую SQLite в Android.Спасибо за ваш вклад

Это мой класс HELPER.Я пропустил открытие и закрытие базы данных, так как это будет слишком долго.После чего я буду вызывать метод для вставки значений в базу данных.

public static final String indexNo = "index_no";
public static final String user_id = "userId";
public static final String company_id = "companyId";
public static final String user_name = "username";
public static final String client_Id = "clientId";
public static final String project_Id = "projectId";
public static final String report_Id = "reportId";
public static final String niv_1  = "niv1";
public static final String niv_2 = "niv2";
public static final String work_type_id = "workTypeId";
public static final String time_type_id = "timeTypeId";
public static final String date_id = "dateId";
public static final String month_id = "monthId";
public static final String year_id = "yearId";
public static final String hourS = "hours";
public static final String private_comment = "privateComment";
public static final String Ncomment = "comment";
public static final String mod_flag = "modFlag";
public static final String new_flag = "newFlag";
public static final String open_flag = "openFlag";
public static final String delete_flag = "deleteFlag";

private static final String DATABASE_NAME = "CopernicusDB.sqlite";
private static final String DATABASE_TABLE = "TimeReportTable";
private static final int    DATABASE_VERSION = 1;

private final Context context;
private static DatabaseHelper DBHelper;
private static SQLiteDatabase db;
private static String TAG = "##---SecondActivityUserHelper---##";
public SecondActivityUserHelper(Context ctx)
{
this.context = ctx;
DBHelper = new DatabaseHelper(context);
}

private static class DatabaseHelper extends SQLiteOpenHelper{

    public DatabaseHelper(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
        Log.v(TAG,"The DatabaseHelper method ");
    }

    public long insertIntoDatabase(String companyId,String username, String dateId,
            String clientId,String projectId,String niv1,String niv2,String workTypeId,String timeTypeId,
            String hours,String comment,String privateComment,String openFlag,String reportId) 
            {
            ContentValues initialValues = new ContentValues();
            initialValues.put(company_id, companyId);
            initialValues.put(user_name, username);
            initialValues.put(date_id,dateId);
            initialValues.put(client_Id,clientId);
            initialValues.put(project_Id,projectId);
            initialValues.put(niv_1,niv1);
            initialValues.put(niv_2,niv2);
            initialValues.put(work_type_id,workTypeId);
            initialValues.put(time_type_id,timeTypeId);
            initialValues.put(hourS, hours);
            initialValues.put(Ncomment, comment);
            initialValues.put(private_comment,privateComment);
            initialValues.put(open_flag, openFlag);
            initialValues.put(report_Id,reportId);
            Log.v(TAG, "Inserted into database sucessfully");
            return db.insert(DATABASE_TABLE, null, initialValues);
            }

}

useradapter.openDatabase();
long id = dB.insertIntoDatabase(  newcompanyid,newusername,newdate,
newClientId,newprojectId,newniv1,newniv2,newworktypeid,newtimetypeid,
newhours,newcomment,newprivatecomment,newopen,newreportid);
                             useradapter.closeDatabase();

Ответы [ 3 ]

4 голосов
/ 19 октября 2011

Создайте объект, который будет содержать ваши данные, например.ClientData
Создать метод для извлечения всех данных из базы данных

public List<ClientData> selectAll() {
   List<ClientData> list = new ArrayList<ClientData>();
   Cursor cursor = this.myDataBase.query(TABLE_NAME, new String[] { "userID, clientName" },
   null, null, null, null, null);
   if (cursor.moveToFirst()) {
        do {
           list.add(new ClientData(cursor.getString(0), cursor.getString(1)));
         } while (cursor.moveToNext());
   }
   if (cursor != null && !cursor.isClosed()) {
         cursor.close();
   }
   return list;
}

Перед выполнением ваших операторов вставки извлеките все данные и затем проверьте, существуют ли данные:

if (!list.contains(clientData)) {
    executeInsert();
}

Я не уверен, поддерживает ли SQLite хранимые процедуры, но если это так, вы могли бы написать и для этого хранимую процедуру.

1 голос
/ 19 октября 2011

В вашем примере таблицы:

Когда вы создаете свою таблицу, вы можете установить свое имя как уникальное (если это то, что вы хотите уникальным) со следующим (Использование SQLiteOpenHelper).

String createPlayerTable = "create table " +
                TIME_REPORT +
                " (" +
                USER_ID + " integer primary key autoincrement not null," +
                CLIENT_NAME + " text not null," +                    
                "UNIQUE("+CLIENT_NAME+")"+
                ");";

Затем вы вставляете insertIntoDatabase метод, используя

db.insertOrThrow(TIME_REPORT, null, initialValues);

вместо

db.insert(TIME_REPORT, null, initialValues);

Это может привести к SQLiteConstraintException, поэтому вам придется добавить try / catch.

Надеюсь, это то, что вам нужно.

1 голос
/ 19 октября 2011

1) если вы ищете уникальный идентификатор, то сделайте поле идентификатора автоматическим приращением и вставьте только значение имени

2), если вы не ищете уникальный, чем получить все данные для этого хранилища таблицымассив, который сравнивает вставленное значение с существующим значением в базе данных

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