sqlite和GreenDao(一)

安卓编程,存储数据,特别是结果比较规则的数据,使用数据库来存储是比较合适的,常用的数据库有原生的sqlite和第三方GreenDao。
下面以一个存储录音的信息为例,展示两种数据库的用法。

sqlite


  • 录音信息Bean:RecorderInfo
public class RecorderInfo{
    private Long id;
    private String name;
    private String dater;
    private String type;
    private String length;
    private String size;
    private String r1;

    public RecorderInfo() {
    }

    public Long getId() {
        return this.id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return this.name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getDater() {
        return this.dater;
    }

    public void setDater(String dater) {
        this.dater = dater;
    }

    public String getType() {
        return this.type;
    }

    public void setType(String type) {
        this.type = type;
    }

    public String getLength() {
        return this.length;
    }

    public void setLength(String length) {
        this.length = length;
    }

    public String getSize() {
        return this.size;
    }

    public void setSize(String size) {
        this.size = size;
    }

    public String getR1() {
        return this.r1;
    }

    public void setR1(String r1) {
        this.r1 = r1;
    }
  • 创建数据库的版本、表、字段:DBConstant
public class DBConstant {
    public static final String DATABASE_NAME = "db";
    public static final int DB_VERSION = 1;
    public static final String TABLE_NAME = "recorder_info";
    public static final String COLUMN_ID = "recorder_id";
    public static final String COLUMN_RECORDER_DATE = "recorder_date";
    public static final String COLUMN_RECORDER_TYPE = "recorder_type";
    public static final String COLUMN_RECORDER_TITLE = "recorder_title";
    public static final String COLUMN_RECORDER_DURATION = "recorder_duration";
    public static final String COLUMN_RECORDER_SIZE = "recorder_size";
    public static final String COLUMN_R1 = "r1";
}

  • 创建数据库的管理工具类:DBHelper
import android.content.ContentValues;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;

import com.xxxx.soundrecorder.base.DBConstant;

public class DBHelper extends SQLiteOpenHelper {
    private static final String TAG=DBHelper.class.getSimpleName();
    public DBHelper(Context context) {
        super(context, DBConstant.DATABASE_NAME, null, DBConstant.DB_VERSION);
    }

    public DBHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
        super(context, name, factory, version);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        createCityInfoTab(db);
        //模拟插入数据
        insertDefault(db)
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }

    /**
     * 创建录音信息表
     *
     * @param db
     */
    private void createCityInfoTab(SQLiteDatabase db) {
        Log.d(TAG,"创建录音信息表");
        String strSQL = "create table "
                + DBConstant.TABLE_NAME
                + "(" + DBConstant.COLUMN_ID + " integer primary key autoincrement,"
                + DBConstant.COLUMN_RECORDER_DATA + " varchar(150), "
                + DBConstant.COLUMN_RECORDER_TITLE + " varchar(10), "
                + DBConstant.COLUMN_RECORDER_TYPE + " varchar(100), "
                + DBConstant.COLUMN_RECORDER_SIZE + " varchar(100), "
                + DBConstant.COLUMN_RECORDER_DURATION+ " varchar(100), "
                + DBConstant.COLUMN_R1 + " varchar(50))";
        db.execSQL(strSQL);
    }

    private void insertDefault(SQLiteDatabase db){
        ContentValues values = new ContentValues();
        values.put(DBConstant.COLUMN_RECORDER_DATE, "2018/5/5");
        values.put(DBConstant.COLUMN_RECORDER_TITLE, "recorder12515");
        values.put(DBConstant.COLUMN_RECORDER_TYPE, "3gp");
        values.put(DBConstant.COLUMN_RECORDER_DURATION, "12");
        db.insert(DBConstant.TABLE_NAME, null, values);
    }
}

  • 数据的操作工具:DBUtil
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;

import com.xxxx.soundrecorder.base.DBConstant;
import com.xxxx.soundrecorder.bean.RecorderInfo;

import java.util.ArrayList;
import java.util.List;

public class DBUtil {
    private final String TAG = DBUtil.class.getSimpleName();
    private DBHelper dbHelper = null;
    private static DBUtil instance = null;

    public static synchronized DBUtil getInstance(Context context) {
        if (instance == null) {
            instance = new DBUtil(context);
        }
        return instance;
    }

    private DBUtil(Context context) {
        dbHelper = new DBHelper(context);
    }

    /**
     * 查询所有录音
     *
     * @return 所有数据
     */
    public List<RecorderInfo> queryAllRecords() {
        List<RecorderInfo> cityInfoModels = new ArrayList<>();
        SQLiteDatabase db = null;
        Cursor cursor = null;
        try {
            db = dbHelper.getReadableDatabase();
            cursor = db.query(DBConstant.TABLE_NAME, new String[]{"*"}, null, null, null, null, null);
            if (cursor != null) {
                while (cursor.moveToNext()) {
                    long id = cursor.getInt(cursor.getColumnIndex(DBConstant.COLUMN_ID));
                    String fileData = cursor.getString(cursor.getColumnIndex(DBConstant.COLUMN_RECORDER_DATE));
                    String fileDate = cursor.getString(cursor.getColumnIndex(DBConstant.COLUMN_RECORDER_TITLE));
                    String fileType = cursor.getString(cursor.getColumnIndex(DBConstant.COLUMN_RECORDER_TYPE));
                    String fileSize = cursor.getString(cursor.getColumnIndex(DBConstant.COLUMN_RECORDER_SIZE));
                    String fileLength = cursor.getString(cursor.getColumnIndex(DBConstant.COLUMN_RECORDER_DURATION));
                    String r1 = cursor.getString(cursor.getColumnIndex(DBConstant.COLUMN_R1));

                    RecorderInfo recorderInfo = new RecorderInfo();
                    recorderInfo.setId(id);
                    recorderInfo.setName(fileData);
                    recorderInfo.setDater(fileDate);
                    recorderInfo.setSize(fileSize);
                    recorderInfo.setType(fileType);
                    recorderInfo.setLength(fileLength);
                    recorderInfo.setR1(r1);

                    cityInfoModels.add(recorderInfo);
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (cursor != null) {
                cursor.close();
            }

            if (db != null) {
                db.close();
            }
        }

        return cityInfoModels;
    }

    /**
     * 插入录音
     *
     * @param recorderInfo 录音
     * @return 操作成功与否
     */
    public synchronized boolean insertRecord(RecorderInfo recorderInfo) {
        boolean isSuccess = false;
        if (recorderInfo == null) {
            return isSuccess;
        }

        SQLiteDatabase db = null;
        try {
            db = dbHelper.getWritableDatabase();
            //开启事务
            db.beginTransaction();
            ContentValues values = new ContentValues();
            values.put(DBConstant.COLUMN_RECORDER_DATE, recorderInfo.getName());
            values.put(DBConstant.COLUMN_RECORDER_TITLE, recorderInfo.getDater());
            values.put(DBConstant.COLUMN_RECORDER_TYPE, recorderInfo.getType());
            values.put(DBConstant.COLUMN_RECORDER_SIZE, recorderInfo.getSize());
            values.put(DBConstant.COLUMN_RECORDER_DURATION, recorderInfo.getLength());
            long no = db.insert(DBConstant.TABLE_NAME, null, values);
            if (no > 0) {
                isSuccess = true;
            }
            db.setTransactionSuccessful();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (db != null) {
                db.endTransaction();
                db.close();
            }
        }

        return isSuccess;
    }

    /**
     * 根据录音ID,删除文件
     *
     * @param id 录音ID
     * @return 操作成功与否
     */
    public synchronized boolean deleteRecord(int id) {
        boolean isSuccess = false;
        SQLiteDatabase db = null;
        try {
            db = dbHelper.getWritableDatabase();
            db.beginTransaction();
            int no = db.delete(DBConstant.TABLE_NAME, " " + DBConstant.COLUMN_ID + "=? ", new String[]{id + ""});
            if (no > 0) {
                isSuccess = true;
            }
            db.setTransactionSuccessful();
        } catch (Exception e) {
            Log.e(TAG, e.getMessage());
        } finally {
            if (db != null) {
                db.endTransaction();
                db.close();
            }
        }

        return isSuccess;
    }

    /**
     * 根据录音名称,删除文件
     *
     * @param fileName 录音名称
     * @return 操作成功与否
     */
    public synchronized boolean deleteRecordByName(String fileName) {
        Log.i(TAG, "deleteRecorderByName=" + fileName);
        boolean isSuccess = false;
        SQLiteDatabase db = null;
        try {
            db = dbHelper.getWritableDatabase();
            db.beginTransaction();
            int no = db.delete(DBConstant.TABLE_NAME, " " + DBConstant.COLUMN_RECORDER_DATE + "=? ", new String[]{fileName + ""});

            if (no > 0) {
                isSuccess = true;
            }
            db.setTransactionSuccessful();
        } catch (Exception e) {
            Log.e(TAG, e.getMessage());
        } finally {
            if (db != null) {
                db.endTransaction();
                db.close();
            }
        }

        return isSuccess;
    }

    /**
     * 根据录音ID,更新录音名称
     *
     * @param id          录音ID
     * @param newFileName 录音名称
     * @returnid 操作成功与否
     */
    public synchronized boolean updateRecordById(long id, String newFileName) {
        Log.i(TAG, "deleteRecorderByName=" + id + ",newFileName=" + newFileName);
        boolean isSuccess = false;
        SQLiteDatabase db = null;
        try {
            db = dbHelper.getWritableDatabase();
            db.beginTransaction();
            ContentValues values = new ContentValues();
            values.put(DBConstant.COLUMN_RECORDER_DATE, newFileName);
//            db.update("tablename", values, "name=?", new String[]{"xiadong"});
//db.update("tablename",values,"name=? AND age=?",new Object{"xiadong", 20});

            db.update(DBConstant.TABLE_NAME, values, DBConstant.COLUMN_ID + "=?", new String[]{id + ""});
            isSuccess = true;
            db.setTransactionSuccessful();
        } catch (Exception e) {
            Log.e(TAG, e.getMessage());
        } finally {
            if (db != null) {
                db.endTransaction();
                db.close();
            }
        }

        return isSuccess;
    }
}

好了。上面就是sqlite的基本用法。greendao的有时间整理在写....

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,475评论 4 372
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,744评论 2 307
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 112,101评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,732评论 0 221
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,141评论 3 297
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,049评论 1 226
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,188评论 2 320
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,965评论 0 213
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,716评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,867评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,341评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,663评论 3 263
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,376评论 3 244
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,200评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,990评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,179评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,979评论 2 279

推荐阅读更多精彩内容

  • 一、关于greenDAO greenDAO应该算是当前最火的数据库开源框架了,它是一个将对象映射到SQLite数据...
    当幸福来敲门58阅读 13,759评论 3 19
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 170,598评论 25 707
  • 一、SQLite 1、SQLite介绍 1.1、简介 SQLite是一款轻型的数据库,是遵守ACID的关联式数据库...
    AndroidMaster阅读 1,904评论 0 7
  • 方所书店的大门上,是诗人也斯的赠语:但愿回到更多诗歌朗读的年代:随风合唱中隐晦了的抒情需要另外的聆听 中学时期的一...
    丁小姐的出口阅读 611评论 0 1
  • 2017.1.13,晴,周五 今天是寒假前的最后一天幼儿园生活,放假回家后,宝贝就迫不及待的展示他那一堆战利品——...
    一禾108阅读 279评论 0 0