android 对象是否存在,如何检查Android中的数据库中是否已存在某个值

在解析JSON响应后,我将使用一个数据库来填充项目.如何检查数据库中是否已存在这些值并阻止再次插入?

例如.数据库名称:Exicom.sqlite

表名:TimeReport

数据库中的字段:userID,clientName

我在android中使用SQLite.

感谢您的输入

这是我的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();

解决方法:

创建一个保存数据的对象,例如. ClientData

创建一个从数据库中获取所有数据的方法

public List selectAll() {

List list = new ArrayList();

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;

}

在执行insert语句之前,获取所有数据,然后检查数据是否存在:

if (!list.contains(clientData)) {

executeInsert();

}

我不确定SQLite是否支持存储过程,但如果确实如此,您也可以编写存储过程.

标签:android,sqlite,database

来源: https://codeday.me/bug/20190826/1733008.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值