如何检查Android中的数据库中是否已经存在值
我有一个数据库,在解析JSON响应后,我将用项目填充该数据库。如何检查数据库中是否已经存在这些值并防止再次插入 例如,数据库名称:Exicom.sqlite 表格名称:TimeReport 数据库中的字段:userID、clientName 我在android中使用SQLite 谢谢你的意见 这是我的助手类。我跳过了打开和关闭数据库,因为它太长了。接下来,我将调用该方法将值插入数据库如何检查Android中的数据库中是否已经存在值,android,database,sqlite,Android,Database,Sqlite,我有一个数据库,在解析JSON响应后,我将用项目填充该数据库。如何检查数据库中是否已经存在这些值并防止再次插入 例如,数据库名称:Exicom.sqlite 表格名称:TimeReport 数据库中的字段:userID、clientName 我在android中使用SQLite 谢谢你的意见 这是我的助手类。我跳过了打开和关闭数据库,因为它太长了。接下来,我将调用该方法将值插入数据库 public static final String indexNo = "index_no"; public
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);
}
}
1)如果要查找唯一id,请将id字段设置为自动递增,并仅插入名称值
2)如果不查找唯一值,则检索数组中此表存储的所有数据,然后将插入值与数据库中的现有值进行比较,创建一个将保存数据的对象,例如
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;
}
我不确定SQLite是否支持存储过程,但如果支持,您也可以为此编写一个存储过程。在示例表中:
创建表时,您可以使用以下命令(使用SQLiteOpenHelper
)将您的名称设置为唯一(如果您想要唯一的话)
然后在您的insertinsertIntoDatabase
方法中使用
db.insertOrThrow(TIME_REPORT, null, initialValues);
而不是
db.insert(TIME_REPORT, null, initialValues);
这可能会抛出一个SQLiteConstraintException
,因此您必须添加一个try/catch
希望这是你需要的
String createPlayerTable = "create table " +
TIME_REPORT +
" (" +
USER_ID + " integer primary key autoincrement not null," +
CLIENT_NAME + " text not null," +
"UNIQUE("+CLIENT_NAME+")"+
");";
db.insertOrThrow(TIME_REPORT, null, initialValues);
db.insert(TIME_REPORT, null, initialValues);