android SQLite使用

这里介绍一些SQLite一些基本常用的方法,参考API手册

首先需要得到一个SQLiteDatabase对象;

SQLiteDatabase db;

db = openOrCreateDatabase("data.db", Context.MODE_PRIVATE, null);

然后再在db中创建一个表;

db.execSQL("CREATE TABLE IF NOT EXISTS table_name (_id INTEGER PRIMARY KEY AUTOINCREMENT, date INTEGER, item TEXT, money INTEGER)"); 

增添数据;

 //按键值保存插入数据,data为事先建立的表,表中有date,item,money三项
 public void SQLiteSave(long date,String item,int money)
 {
  data.date = date;
  data.item = item;
  data.money = money;
        ContentValues cv = new ContentValues(); 
        cv.put("date", data.date); 
        cv.put("item", data.item);
        cv.put("money", data.money);
        //插入ContentValues中的数据 
        db.insert("data", null, cv);
 }

//更新数据;先根据date,item,money找到已经存在的数据,得到主键_id,再根据_id将date替换为new_date

 public void SQLiteUpdateDate(long date,String item,int money,long new_date)
 {
  String var_date=String.valueOf (date);
  String var_money=String.valueOf (money);
  ContentValues cv = new ContentValues(); 
  cv.put("date", new_date);
  
  Cursor c = db.rawQuery("SELECT * FROM data WHERE date = ? AND item = ? AND money = ?", new String[]{var_date,item,var_money});  
  while (c.moveToNext())
  {
   String _id = String.valueOf(c.getInt(c.getColumnIndex("_id")));
   db.update("data", cv, "_id = ? ", new String[]{_id});
  }
  c.close(); 
 }

//删除数据,根据date,item,money得到主键_id然后删除

 public void SQLiteDelete(long date,String item,int money)
 {
  String var_date=String.valueOf (date);
  String var_money=String.valueOf (money);
  Cursor c = db.rawQuery("SELECT * FROM data WHERE date = ? AND item = ? AND money = ?", new String[]{var_date,item,var_money});  
  while (c.moveToNext())
  {
   String _id = String.valueOf(c.getInt(c.getColumnIndex("_id")));
   db.delete("data", "_id = ?", new String[]{_id});
  }
  c.close();
 }

这里只是提供一种方法

posted @ 2013-12-03 15:34  delay疯子  阅读(288)  评论(0编辑  收藏  举报