zoukankan      html  css  js  c++  java
  • Android 下的 SQLite 操作封装 —— DatabaseUtil

    看到别人写的代码不错,对自己目前的开发很有用,所以转载一下,希望也能帮助到其他人:

    1.DatabaseUtil.java(封装的类)

    package com.dbexample;
     
    import android.content.ContentValues;
    import android.content.Context;
    import android.database.Cursor;
    import android.database.SQLException;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteOpenHelper;
    import android.util.Log;
     
    public class DatabaseUtil{
     
        private static final String TAG = "DatabaseUtil";
     
        /**
         * Database Name
         */
        private static final String DATABASE_NAME = "student_database";
     
        /**
         * Database Version
         */
        private static final int DATABASE_VERSION = 1;
     
        /**
         * Table Name
         */
        private static final String DATABASE_TABLE = "tb_student";
     
        /**
         * Table columns
         */
        public static final String KEY_NAME = "name";
        public static final String KEY_GRADE = "grade";
        public static final String KEY_ROWID = "_id";
     
        /**
         * Database creation sql statement
         */
        private static final String CREATE_STUDENT_TABLE =
            "create table " + DATABASE_TABLE + " (" + KEY_ROWID + " integer primary key autoincrement, "
            + KEY_NAME +" text not null, " + KEY_GRADE + " text not null);";
     
        /**
         * Context
         */
        private final Context mCtx;
     
        private DatabaseHelper mDbHelper;
        private SQLiteDatabase mDb;
     
        /**
         * Inner private class. Database Helper class for creating and updating database.
         */
        private static class DatabaseHelper extends SQLiteOpenHelper {
            DatabaseHelper(Context context) {
                super(context, DATABASE_NAME, null, DATABASE_VERSION);
            }
            /**
             * onCreate method is called for the 1st time when database doesn't exists.
             */
            @Override
            public void onCreate(SQLiteDatabase db) {
                Log.i(TAG, "Creating DataBase: " + CREATE_STUDENT_TABLE);
                db.execSQL(CREATE_STUDENT_TABLE);
            }
            /**
             * onUpgrade method is called when database version changes.
             */
            @Override
            public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
                Log.w(TAG, "Upgrading database from version " + oldVersion + " to "
                        + newVersion);
            }
        }
     
        /**
         * Constructor - takes the context to allow the database to be
         * opened/created
         *
         * @param ctx the Context within which to work
         */
        public DatabaseUtil(Context ctx) {
            this.mCtx = ctx;
        }
        /**
         * This method is used for creating/opening connection
         * @return instance of DatabaseUtil
         * @throws SQLException
         */
        public DatabaseUtil open() throws SQLException {
            mDbHelper = new DatabaseHelper(mCtx);
            mDb = mDbHelper.getWritableDatabase();
            return this;
        }
        /**
         * This method is used for closing the connection.
         */
        public void close() {
            mDbHelper.close();
        }
     
        /**
         * This method is used to create/insert new record Student record.
         * @param name
         * @param grade
         * @return long
         */
        public long createStudent(String name, String grade) {
            ContentValues initialValues = new ContentValues();
            initialValues.put(KEY_NAME, name);
            initialValues.put(KEY_GRADE, grade);
            return mDb.insert(DATABASE_TABLE, null, initialValues);
        }
        /**
         * This method will delete Student record.
         * @param rowId
         * @return boolean
         */
        public boolean deleteStudent(long rowId) {
            return mDb.delete(DATABASE_TABLE, KEY_ROWID + "=" + rowId, null) > 0;
        }
     
        /**
         * This method will return Cursor holding all the Student records.
         * @return Cursor
         */
        public Cursor fetchAllStudents() {
            return mDb.query(DATABASE_TABLE, new String[] {KEY_ROWID, KEY_NAME,
                    KEY_GRADE}, null, null, null, null, null);
        }
     
        /**
         * This method will return Cursor holding the specific Student record.
         * @param id
         * @return Cursor
         * @throws SQLException
         */
        public Cursor fetchStudent(long id) throws SQLException {
            Cursor mCursor =
                mDb.query(true, DATABASE_TABLE, new String[] {KEY_ROWID,
                        KEY_NAME, KEY_GRADE}, KEY_ROWID + "=" + id, null,
                        null, null, null, null);
            if (mCursor != null) {
                mCursor.moveToFirst();
            }
            return mCursor;
        }
     
        /**
         * This method will update Student record.
         * @param id
         * @param name
         * @param standard
         * @return boolean
         */
        public boolean updateStudent(int id, String name, String standard) {
            ContentValues args = new ContentValues();
            args.put(KEY_NAME, name);
            args.put(KEY_GRADE, standard);
            return mDb.update(DATABASE_TABLE, args, KEY_ROWID + "=" + id, null) > 0;
        }
    }
    2.代码使用方法

    //插入
    DatabaseUtil dbUtil = new DatabaseUtil(this);
    dbUtil.open();
    dbUtil.createStudent("Prashant Thakkar", "10th");
    dbUtil.close();
     
    //查询
    DatabaseUtil dbUtil = new DatabaseUtil(this);
    dbUtil.open();
    Cursor cursor = dbUtil.fetchAllStudents();
    if(cursor != null){
       while(cursor.moveToNext()){
        Log.i("Student", "Student Name: " + cursor.getString(1) +
                   " Grade " + cursor.getString(2));
       }
    }
    dbUtil.close();



  • 相关阅读:
    硬核动图让你轻松弄懂递归,查找等概念
    Instagram API平台文档
    盲人都能编程,你有什么资格说自己不行
    10个经典智力推理题!据说答对7道,智力在140!
    我们该如何高效的学习
    从一碗小米粥谈装饰器模式,代理模式的区别
    html+css实现彩色渐变滑动条
    css实现彩色渐变滑动条
    [极客大挑战 2019]Knife 思路
    buuctf
  • 原文地址:https://www.cnblogs.com/sowhat4999/p/4439856.html
Copyright © 2011-2022 走看看