0

我正在开发一个 Android 应用程序,我在其中搜索在给定日期之后创建的记录。我的代码是这样的

public List<NPRMember> IncrementalData(String LastDtTime) {

List<NPRMember> results = new ArrayList<NPRMember>();
SQLiteDatabase db=getMyReadableDatabase();
String lastdt="datetime("+LastDtTime+")";
Cursor cursor = null;

try{

      cursor = db.query(TABLE_NAME_NPR, new String[] { KEY_FULLNAME, KEY_FATHERNAME, 
       KEY_RCRD_SOURCE,KEY_RCRD_CRN_DATE},KEY_RCRD_CRN_DATE + ">? AND "+KEY_RCRD_SOURCE+">?",
               new String[]{lastdt, "0"}, null, null, null); 


    cursor.moveToFirst();
    while (!cursor.isAfterLast()) {
            NPRMember nprmem = cursorToMemberDetails(cursor);
            results.add(nprmem);          
            cursor.moveToNext();

    }
}catch(Exception e){
    Log.e(APP_NAME, "An error occurred while searching for "+LastDtTime+": "+e.toString(), e);
}finally{
    if(cursor!=null && !cursor.isClosed()){
        cursor.close();
    }
}

return results;

}

该查询没有返回任何值,尽管我至少有一条记录 KEY_RCRD_CRN_DATE 2013-07-25 18:59:19 作为参数传递的 LastDtTime 的值为 2013-07-25 14:46:03。一件有趣的事情是,如果我在 SQLite 命令提示符处运行查询,它会返回 deisred 记录。

  SELECT fullname, fathername, .... rcrdsource, rcrdcrtndate FROM nprmembers WHERE rcrdcrtndate>'2013-07-25
 14:46:03' AND rcrdsource>0;

任何帮助,将不胜感激。谢谢

4

1 回答 1

0

参数值 (in lastdt) 错误。

您想要的是字符串2013-07-25 18:59:19,但实际上您正在使用字符串datetime(2013-07-25 18:59:19)。字母d在 之后2,因此没有记录匹配。

将初始化更改lastdt为:

String lastdt=LastDtTime;
于 2013-07-25T14:10:27.767 回答