如何在SQLite中插入日期?

时间:2016-09-06 18:46:22

标签: android sqlite android-sqlite

我有这个错误:

  

无法解析方法'put(java.lang.String,java.util.Date)'

在下面的代码中: enter image description here

lsdnsd是数据类型为DATE的列名。

public void onCreate(SQLiteDatabase db)
{
    String query="CREATE TABLE"+c_tablename+"(c_id int AUTO_INCREMENT primary key,name varchar(20),contact double ,address varchar(50)," +
            "bike_number varchar(16),bike_type varchar(10),lsd date,nsd date,lwd varchar(100),cost int,message varchar(100))";
    db.execSQL(query);

}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
{
    String query= "DROP TABLE IF EXIST "+c_tablename;
    String query2="DROP TABLE IF EXIST "+h_tablename;
    db.execSQL(query);
    db.execSQL(query2);

    onCreate(db);
}

public void  saveData(String name , int contact , String address , String bike_number , String bike_type , java.util.Date lsd  ,
                      java.util.Date nsd , String lwd , int cost , String message )
{
    ContentValues contentValues=new ContentValues();
    contentValues.put("name",name);
    contentValues.put("contact",contact);
    contentValues.put("address",address);
    contentValues.put("bike_number",bike_number);
    contentValues.put("bike_type",bike_type);
    contentValues.put("lsd",lsd);
    // The error is in the following line ("Cannot resolve method 'put(java.lang.String, java.util.Date)'"):
    contentValues.put("nsd",nsd);
    contentValues.put("lwd",lwd);
    contentValues.put("cost",cost);
    contentValues.put("message",message);
}

2 个答案:

答案 0 :(得分:3)

Akshay 显示了解决问题的正确方法。

背景信息是SQLite不支持日期类型:

  

SQLite没有预留用于存储日期和/或时间的存储类。相反,SQLite的内置日期和时间函数能够将日期和时间存储为TEXT,REAL或INTEGER值

请参阅https://www.sqlite.org/datatype3.html#section_2_2

上的SQLite文档

答案 1 :(得分:2)

你可以试试这样的事吗,

SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
ContentValues contentValues=new ContentValues();
contentValues.put("lsd", dateFormat.format(lsd));