0

要将日历对象存储在 SQLite 数据库中,我发现最简单的方法是将日历对象转换为字符串并将其作为文本存储在数据库中。

现在,问题在于从字符串中提取存储的日期。

如何解析包含 Calendar 对象的字符串并将其设置为 Calendar 值?

我的代码是:

    String CREATE_DOCTORS_TABLE = "CREATE TABLE " + TABLE_DOCTORS + "("
            + KEY_ID_DOC + " INTEGER PRIMARY KEY," + KEY_DOCTOR_NAME + " TEXT,"             
            + KEY_CLINIC_ADDRESS + " TEXT," + KEY_LAST_CHECKUP + " TEXT" + ");";
    db.execSQL(CREATE_DOCTORS_TABLE);       

其中 KEY_LAST_CHECKUP 包含如下值:

java.util.GregorianCalendar[time=?,areFieldsSet=false,lenient=true,zone=Asia/Calcutta,firstDayOfWeek=1,minimalDaysInFirstWeek=1,ERA=1,YEAR=2013,MONTH=4,WEEK_OF_YEAR=29,WEEK_OF_MONTH=3,DAY_OF_MONTH=16,DAY_OF_YEAR=198,DAY_OF_WEEK=4,DAY_OF_WEEK_IN_MONTH=3,AM_PM=1,HOUR=4,HOUR_OF_DAY=16,MINUTE=19,SECOND=47,MILLISECOND=823,ZONE_OFFSET=19800000,DST_OFFSET=0]

我以这种方式将其存储在数据库中:

values.put(KEY_LAST_CHECKUP, (doctor.getLastCheckUpDate().toString())); // last check up date

现在,我如何从存储的字符串中检索 DAY、MONTH 和 YEAR?

我在这里阅读了有关如何将日期字符串转换为日历对象的信息: 如何将日期字符串转换为日期或日历对象?

但我的字符串不仅仅是日期字符串。它还包含许多其他细节。

最好的前进方式是什么?

4

2 回答 2

5

更改您的数据模型以使用Date. 这是存储在数据库中的常用类型。

您可以Date使用Calendar

Calendar c = Calendar.getInstance();
c.setTime(date);

Date要从Calendar您可以使用的检索

date = c.getTime();

使用 aString将 a 存储Date在数据库中需要对 s 进行格式化和解析,String并且在数据库之外也无法进行比较。

于 2013-07-17T11:08:43.613 回答
3

如果您想在KEY_LAST_CHECKUP列中保留字符串值。尝试使用SimpleDateFormat.

如果你保持长期价值,你不需要使用SimpleDateFormat.

对于插入:

SimpleDateFormat simpleFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
String strDate = simpleFormat.format(doctor.getLastCheckUpDate());
values.put(KEY_LAST_CHECKUP, strDate);

对于检索:

try {
    String strDate = --> from DB
    Date parsedDate = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS").parse(strDate);
    Calendar c = Calendar.getInstance();
    c.setTime(parsedDate);
} catch (ParseException e) {
    return "Unknown";
}
于 2013-07-17T11:28:16.307 回答