SQLite的insert、delete、update操作

 SQLiteDatabase的学习,我们应该重点掌握execSQL()和rawQuery()方法。 execSQL()方法可以执行insert、delete、update和CREATE TABLE之类有更改行为的SQL语句。

其内部是拼凑SQL语句来实现的,性能没有 execSQL()和rawQuery()方法好!!!

public class OtherPersonService {
 private DBOpenHelper dbOpenHelper;
 
 public OtherPersonService(Context context) {
  this.dbOpenHelper = new DBOpenHelper(context);
 }

 public void save(Person person){
  SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
  ContentValues values = new ContentValues();//通过ContentValues对象来传入参数
  values.put("name", person.getName());
  db.insert("person", null, values);
 }
 
 public void update(Person person){
  // update person set name =? where personid =?
  SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
  ContentValues values = new ContentValues();
  values.put("name", person.getName());
  db.update("person", values, "personid=?", new String[]{person.getId().toString()});
 }
 
 public void delete(Integer id){
  SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
  db.delete("person", "personid=?", new String[]{id.toString()});
 }
 
 public Person find(Integer id){
  //如果只对数据进行读取,建议使用此方法
  SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
  Cursor cursor = db.query("person", new String[]{"personid", "name"},
    "personid=?", new String[]{id.toString()}, null, null, null);
  //select personid,name from person where personid=? order by ... limit 3,5
  if(cursor.moveToFirst()){
   int personid = cursor.getInt(cursor.getColumnIndex("personid"));
   String name = cursor.getString(cursor.getColumnIndex("name"));
   return new Person(personid, name);
  }
  return null;
 }

 public List<Person> getScrollData(Integer offset, Integer maxResult){
  List<Person> persons = new ArrayList<Person>();
  SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
  Cursor cursor = db.query("person", null, null, null, null, null, null, offset+","+ maxResult);
  while(cursor.moveToNext()){
   int personid = cursor.getInt(cursor.getColumnIndex("personid"));
   String name = cursor.getString(cursor.getColumnIndex("name"));
   Person person = new Person(personid, name);
   persons.add(person);
  }
  cursor.close();
  return persons;
 }

 public long getCount() {// select count(*) from person
  SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
  Cursor cursor = db.query("person", new String[]{"count(*)"}, null, null, null, null, null);
  cursor.moveToFirst();
  return cursor.getLong(0);
 }
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值