Android数据存储之SQlite(上)

之前简单的总结了一下Android开发中SharedPreferences的使用,我觉得并不是很难,有了解Java键值对相关知识的人都可以轻松使用。

接下来想说一下Android的另一个存储工具,也就是最常用功能最强大的Android数据库SQlite。

Sqlite是什么我就不多废话,大家不妨去百度一下,很多资料。我想简单的总结一下我是如何在实际开发过程中使用Sqlite的。(由于一开始不知道Greendao框架,所以直接是用的手写SQL语句。)

提到SQLite 就不能不说一下SQLiteOpenHelper这个类。 这个类是Android平台提供给我们一个数据库辅助类来创建或打开数据库,有兴趣的可以阅读一下这个类的源码。

那么我们该如何使用这个类呢?

首先 我们可以创建一个自己的DBHelpr类,用来继承SQLiteOpenHelper,然后重写它的onCreate()和onUpgrade()方法,具体代码如下:

public class DBHelper extends SQLiteOpenHelper {

    /**
     * 登录人员表.
     */
    public static final String TABLE_LoginMan_NAME = "LoginMan";
    /**
     * 登陆人员 sql语句.
     */
    private String sql_create_LoginMan = "CREATE TABLE IF NOT EXISTS " +
            TABLE_LoginMan_NAME +
            "(loginId VARCHAR PRIMARY KEY ," +
            "loginName VARCHAR," +
            "password VARCHAR," +
            "flag VARCHAR," +
            "line VARCHAR)";
    
    public DBHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
        super(context, name, factory, version);
    }

    
    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL(sql_create_LoginMan);
    }
    
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }
}

这样我们就有了数据库和数据表,但是更重要的是需要操作数据库,也就是传统的“增删改查”的操作。对于这类操作,我们可以另外建一个类,名字就叫DBManager。在DBManager中,我们需要实例化DBhelper,然后写一些“增删改查”的Sql语句。具体代码如下:

public class DBManager {
    private DBHelper helper;
    private SQLiteDatabase db;

    public DBManager(Context context) {
        helper = new DBHelper(context);
    }

     /**
         * add LoginMan
         *
         * @param loginMen
         */
        public void addLoginMan(List<LoginMan> loginMen) {
            try {
                ContentValues values = new ContentValues();
                for (LoginMan loginMan : loginMen) {
                    db = helper.getWritableDatabase();
                    values.put("loginId", loginMan.getLoginId());
                    values.put("loginName", loginMan.getLogin_name());
                    values.put("password", loginMan.getPassword());
                    values.put("flag", loginMan.getFlag());
                    values.put("line", loginMan.getLine());
                    db.insert(DBHelper.TABLE_LoginMan_NAME, null, values);
                    db.close();
                }
            } finally {
                //            db.endTransaction();//结束事物
            }
        }
}

这样 我们就可以直接操作实体类,然后调用DBManager中的addLoginMan来增加登陆人员了。 由于我项目中“删改查”的代码是根据自己的需求单独写的,不具有参考意义,这里就不放出来了。大家感兴趣的话可以参考Android SQLite详解这篇文章。

SQLite的基本使用方法就先总结到这里,下一篇打算总结一下如何使用开源框架来操作数据库(greendao)
Android数据存储之SQlite(下)

    原文作者:pokerfaceCmy
    原文地址: https://www.jianshu.com/p/fa90c19f4de4
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞