原文地址:http://blog.csdn.net/intbird

项目里使用的是greeDao,sqllite是以前练习使用的,

如果项目里全用这个,人会比较累;

然而greenDao使用起来非常方便,可以说是三分钟速成

如不明白请看官方文档,源码里也有详细说明.

===================
@GreenDao

官网链接:http://greendao-orm.com/documentation/how-to-get-started/

官网DEMO:https://github.com/greenrobot/greenDAO

public static void save(Locations locs) {SQLiteDatabase db = Frame.getInstance().getDbHelp().getWritableDatabase();DaoMaster master = new DaoMaster(db);DaoSession session = master.newSession();DbLocationsDao locsDao = session.getDbLocationsDao();locsDao.insertOrReplace(locs); ;db.close();}public static void deletedFromLast(long lastId){SQLiteDatabase db = Frame.getInstance().getDbHelp().getWritableDatabase();DaoMaster master = new DaoMaster(db);DaoSession session = master.newSession();DbLocationsDao locsDao = session.getDbLocationsDao();QueryBuilder query = locsDao.queryBuilder();DeleteQuery delete = query.where(Properties.Time.le(lastId)).buildDelete();delete.executeDeleteWithoutDetachingEntities();db.close();}public static long getDbSize(){SQLiteDatabase db = Frame.getInstance().getDbHelp().getWritableDatabase();DaoMaster master = new DaoMaster(db);DaoSession session = master.newSession();DbLocationsDao locsDao = session.getDbLocationsDao();long size = locsDao.queryBuilder().count();return size;}public static List getDataBySize(int size){SQLiteDatabase db = Frame.getInstance().getDbHelp().getWritableDatabase();DaoMaster master = new DaoMaster(db);DaoSession session = master.newSession();DbLocationsDao locsDao = session.getDbLocationsDao();List list =  locsDao.queryBuilder().limit(size).orderAsc(Properties.Time).build().list();db.close();return list;}

   ============   

@SqlLiteOpenHelper

例子

package mode;import java.util.ArrayList;import java.util.HashMap;import java.util.Map;import core.override.MyselfDishAdapter;import android.content.ContentValues;import android.content.Context;import android.database.Cursor;import android.database.sqlite.*;public class DishSqlite extends SQLiteOpenHelper {private static final String TB_NAME = "tb_dishMode";private static final String CREATE_TABLE_SQL = "create table "+TB_NAME+"("+ DishMode.ds_id+" integer primary key autoincrement,"+ DishMode.ds_name+" text,"+ DishMode.ds_cover+"  text,"+ DishMode.ds_img+ " text," + DishMode.ds_tips+ " text," + DishMode.ds_addTime+ " text)";public DishSqlite(Context context) {super(context, TB_NAME, null, 1);}@Overridepublic void onCreate(SQLiteDatabase db) {db.execSQL(CREATE_TABLE_SQL);}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {// db.execSQL("ALTER TABLE tb_student ADD COLUMN other STRING");// SCHMA_VERSION}public void executeSql(String sql) {this.getWritableDatabase().execSQL(sql);this.getWritableDatabase().close();}/**** 查询**/public ArrayList> getAllDataInDB(String state) {ArrayList> listmap = new ArrayList>();Cursor cur = getWritableDatabase().query(TB_NAME, null, null, null,null, null, null);// 查询并获得游标if (cur.moveToFirst()) {// 判断游标是否为空do {Map map=new HashMap();int id = cur.getInt(cur.getColumnIndex(DishMode.ds_id ));String statedb=cur.getString(cur.getColumnIndex(DishMode.ds_state));if(statedb.equals(state)){String name=cur.getString(cur.getColumnIndex(DishMode.ds_name));String dishCover=cur.getString(cur.getColumnIndex(DishMode.ds_cover));String dishTime=cur.getString(cur.getColumnIndex(DishMode.ds_addTime));map.put("id", id+"");map.put("style", MyselfDishAdapter.styleNormal+"");map.put("name", name);map.put("img", dishCover);map.put("addTime", dishTime);listmap.add(map);}} while (cur.moveToNext());cur.close();this.getWritableDatabase().close();}return listmap;}/** * 插入一条数据; */public int insert(DishMode upData) {ContentValues cv = new ContentValues();cv.put(DishMode.ds_name, upData.getName());cv.put(DishMode.ds_cover, upData.getCover());cv.put(DishMode.ds_img, upData.getImg());cv.put(DishMode.ds_state, upData.getState());cv.put(DishMode.ds_burden, upData.getBurden());cv.put(DishMode.ds_makes, upData.getMakes());cv.put(DishMode.ds_tips, upData.getTips());cv.put(DishMode.ds_addTime, upData.getAddTime());long id = this.getWritableDatabase().insert(TB_NAME, null, cv);this.getWritableDatabase().close();return (int)id;}/** * 修改一条数据; */public int update(DishMode upData) {ContentValues cv = new ContentValues();cv.put(DishMode.ds_name, upData.getName());cv.put(DishMode.ds_cover, upData.getCover());cv.put(DishMode.ds_img, upData.getImg());cv.put(DishMode.ds_state, upData.getState());cv.put(DishMode.ds_burden, upData.getBurden());cv.put(DishMode.ds_makes, upData.getMakes());cv.put(DishMode.ds_tips, upData.getTips());cv.put(DishMode.ds_addTime, upData.getAddTime());int row= this.getWritableDatabase().update(TB_NAME, cv,null,null);this.getWritableDatabase().close();return row;}/** * 删除 */public boolean deleteById(int id) {int i = this.getWritableDatabase().delete(TB_NAME, DishMode.ds_id+"=" +  Integer.valueOf(id) + "",null);this.getWritableDatabase().close();if (i > 0)return true;elsereturn false;}


更多相关文章

  1. SpringBoot 2.0 中 HikariCP 数据库连接池原理解析
  2. 一句话锁定MySQL数据占用元凶
  3. SQlite数据库框架:LitePal
  4. Android项目清单文件
  5. Android(安卓)Studio运行项目提示Edit configuration
  6. Android之Fragment学习(四)
  7. Android中从网络获取数据的方法
  8. AOSP: 导入项目报错
  9. Android(安卓)与SQlite 数据库操作(新手步骤)

随机推荐

  1. Android(安卓)3.0,将为对战iPad归来
  2. Android——BroadcastReceiver总结
  3. Google发布App开发准则 为自主Android平
  4. 关于使用Android(安卓)NDK编译ffmpeg
  5. Android中对Log日志文件的分析
  6. 想抢先体验Android操作系统的魅力吗?那就
  7. Android通过Socket(TCP/IP)与PC通讯
  8. 环境装好后,创建手机的模拟器
  9. 新手学习linux需了解的内容
  10. Android(安卓)2.3系统令人为之兴奋的十大