数据库是Android存储方案的核心,在Andorid中SQLite非常轻量,而且执行sql语句甚至比mysql还要快。
SQLiteDatabase 是 Android 中操作数据库的核心类之一,使用SQLiteDatabase可以打开数据库,也可以对数据库进行操作,然而,为了数据库升级以及使用更加方便,我们常用SQLiteOpenHelper的子类来完成创建,打开数据库的操作。
SQLiteOpenHelper是一个抽象类,在该类中有下面两个必须实现的方法:

  • public void onCreate(SQLiteDatabase db);// 该函数在数据库第一次被建立时调用
  • public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion);// 数据库更新升级操作

我们新建一个类DBHelper extends SQLiteOpenHelper

import java.util.Random;import android.R.bool;import android.content.Context;import android.database.Cursor;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteDatabase.CursorFactory;import android.database.sqlite.SQLiteOpenHelper;public class DBHelper extends SQLiteOpenHelper {    // 设置数据库默认版本    private static final int VERSON = 1;    // 自定义数据库名,可以随便取名字    private static final String DBNAME = "mydb";    // 继承SQLiteOpenHelper类的类必须有自己的构造函数    // 该构造函数4个参数,直接调用父类的构造函数。其中第一个参数为该类本身;第二个参数为数据库的名字;    public DBHelper(Context context, String name, CursorFactory factory,            int version) {        super(context, name, factory, version);    }    // 该构造函数有3个参数,因为它把上面函数的第3个参数固定为null了    public DBHelper(Context context, String name, int verson) {        this(context, name, null, verson);    }    // 该构造函数只有2个参数,在上面函数 的基础上将版本号固定了    public DBHelper(Context context, String name) {        this(context, name, VERSON);    }    // 该构造函数只有1个参数,固定默认数据库,在这里我们实现增删改查为了方便,就用它了    public DBHelper(Context context) {        this(context, DBNAME, null, VERSON);    }    // 该函数在数据库第一次被建立时调用    public void onCreate(SQLiteDatabase db) {        System.out.println("create a sqlite database");        //建表语句(注意:因为在绑定数据时,Cursor对象返回的记录集中必须包含一个"_id"字段,否则无法完成数据绑定        String sql = "CREATE TABLE [test]("+                        "[_id] AUTOINC,"+                        "[name] varchar(20),"+                        "[age] varchar(20),"+                        "PRIMARY KEY ([_id]))";        db.execSQL(sql);        //向test表中插入10条数据        for (int i = 1; i <= 10; i++) {            String name = "Jepson";            name+=i;            String age = "age";            age+=i;            db.execSQL("insert into test(name,age) values(?,?)",new Object[]{name,age});        }    }    // 数据库更新操作    public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {        System.out.println("update a sqlite database");    }    //自定义query方法,用以执行查询语句,返回Cursor对象    public Cursor query(String sql,String[] args){        //调用 getReadableDatabase方法时,如果数据库文件不存在,会调用 onCreate方法        SQLiteDatabase db = this.getReadableDatabase();        Cursor cursor = db.rawQuery(sql, args);        return cursor;    }}

这样,我们的DBHelper 类写好了,我们来实现一个查询操作。

第一步,activity_main.xml添加 listview 展示控件

activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#FFFFFF" android:orientation="vertical" tools:context=".MainActivity" >    <ListView  android:id="@android:id/list" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_weight="1" android:divider="#6b6f74" android:dividerHeight="1px" >    </ListView></LinearLayout>

第二步,新建一个xml布局文件,用来作为列表项使用的布局资源

user_list_cell.xml

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:background="#FFFFFF">    <!-- 大字体TextView,用以展示 name姓名 -->    <TextView  android:id="@+id/tvName" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="Large" android:textColor="#000000" android:textSize="20dp" />    <!-- 小字体TextView,用以展示 age年龄 -->    <TextView  android:id="@+id/tvAge" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="Small" android:textColor="#000000" android:textSize="14dp" /></LinearLayout>

第三步,主Activity

import android.os.Bundle;import android.app.Activity;import android.app.ListActivity;import android.database.Cursor;import android.support.v4.widget.SimpleCursorAdapter;import android.view.Menu;import android.widget.Toast;public class MainActivity extends ListActivity {    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        initView();    }    public void initView(){        //调用只有1个参数的构造函数,实例化dbHelper        DBHelper dbHelper = new DBHelper(this);        //新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录        Cursor cursor = dbHelper.query("select * from test", null);        //创建SimpleCursorAdapter对象,5个参数,        //第一个是context,就写当前this就行        //第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml        //第三个就是Cursor对象        //第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age        //第五个就是对应列表项布局中的控件ID了        SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,                R.layout.user_list_cell, cursor,                new String[] { "name", "age" }, new int[] { R.id.tvName,                        R.id.tvAge });        setListAdapter(simpleCursorAdapter);        Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();    }}

执行一下看看,我们是不是查询成功了?

操作SQLite数据库应了解,对数据库的增删改查都有两种方法,一种是前面的使用 rawQuery方法直接执行SQL语句,另一种就是使用SQLiteDatabase类的相应方法来操作,下面举一个第二种的例子,比如我们要插入数据 name=11 age=22

import android.os.Bundle;import android.app.Activity;import android.app.ListActivity;import android.database.Cursor;import android.support.v4.widget.SimpleCursorAdapter;import android.view.Menu;import android.widget.Toast;public class MainActivity extends ListActivity {    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        initView();    }    public void initView(){        //执行添加操作        DBHelper dbHelper = new DBHelper(this);        //获得写入权限getWritableDatabase        SQLiteDatabase db = dbHelper.getWritableDatabase();        //新建contentvalues保存insert数据        ContentValues cv = new ContentValues();        cv.put("name", "11");        cv.put("age", "22");        db.insert("test", null, cv);        Toast.makeText(this, "添加成功", Toast.LENGTH_SHORT).show();        ////查询操作        ////调用只有1个参数的构造函数,实例化dbHelper        //DBHelper dbHelper = new DBHelper(this);        ////新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录        //Cursor cursor = dbHelper.query("select * from test", null);        ////创建SimpleCursorAdapter对象,5个参数,        ////第一个是context,就写当前this就行        ////第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml        ////第三个就是Cursor对象        ////第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age        ////第五个就是对应列表项布局中的控件ID了        //SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,        // R.layout.user_list_cell, cursor,        // new String[] { "name", "age" }, new int[] { R.id.tvName,        // R.id.tvAge });        //setListAdapter(simpleCursorAdapter);        //Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();    }}       

执行插入成功以后,再将插入语句注释,将查询语句去掉注释,重新启动,会发现最后一多了一个item,添加成功。

另外查询记录获得的Cursor对象,需要使用movetoFirst,moveToNext,movToPosition(position)等方法将指针移动相应的位置,来进行查询结果的读取。

import android.os.Bundle;import android.app.Activity;import android.app.ListActivity;import android.database.Cursor;import android.support.v4.widget.SimpleCursorAdapter;import android.view.Menu;import android.widget.Toast;public class MainActivity extends ListActivity {    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        initView();    }    public void initView(){        //解析Cursor对象的查询操作        DBHelper dbHelper = new DBHelper(this);        SQLiteDatabase db = dbHelper.getWritableDatabase();        Cursor cursor = db.query("test", null, null, null, null, null, null,                null);        //定义结果字符串        String result = "";        // 判断cursor不为空 这个很重要        if (cursor != null) {            while (cursor.moveToNext()) {                String name = cursor.getString(cursor.getColumnIndex("name"));// 获取name列的值                String age = cursor.getString(cursor.getColumnIndex("age"));// 获取age列的值                result += "姓名:" + name + ",年龄:" + age + "\n";            }        }        cursor.close();        db.close();        System.out.println(result);        Toast.makeText(this, result, Toast.LENGTH_SHORT).show();        // //执行添加操作        // DBHelper dbHelper = new DBHelper(this);        // //获得写入权限getWritableDatabase        // SQLiteDatabase db = dbHelper.getWritableDatabase();        // //新建contentvalues保存insert数据        // ContentValues cv = new ContentValues();        // cv.put("name", "11");        // cv.put("age", "22");        // db.insert("test", null, cv);        // Toast.makeText(this, "添加成功", Toast.LENGTH_SHORT).show();        ////查询操作        ////调用只有1个参数的构造函数,实例化dbHelper        //DBHelper dbHelper = new DBHelper(this);        ////新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录        //Cursor cursor = dbHelper.query("select * from test", null);        ////创建SimpleCursorAdapter对象,5个参数,        ////第一个是context,就写当前this就行        ////第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml        ////第三个就是Cursor对象        ////第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age        ////第五个就是对应列表项布局中的控件ID了        //SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,        // R.layout.user_list_cell, cursor,        // new String[] { "name", "age" }, new int[] { R.id.tvName,        // R.id.tvAge });        //setListAdapter(simpleCursorAdapter);        //Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();    }}       

执行以后,可以发现,name和age全都获取到了,并显示在了Toast和system.out中。是不是很有意思呢?

更多相关文章

  1. Android 高手进阶教程(十三)之----Android 数据库SQLiteDatabase
  2. Android数据库加密
  3. Android 数据库SQLite的使用简单Demo
  4. 读取指定路径数据库的方法
  5. 对android内置的sqlLite数据库进行增、删、改、查操作
  6. Android Afinal框架学习(一) FinalDb 数据库操作
  7. android webview 添加内置对象
  8. android(17)_数据存储与访问_SQLite数据库_修改数据库

随机推荐

  1. Android ListView 设置分割线的设置
  2. 学习 Android Handler 消息机制需要注意
  3. Adapter相关资料
  4. Android 文件保存与读取
  5. Android中onInterceptTouchEvent与onTouc
  6. Android调试笔记——FATAL EXCEPTION: ma
  7. Android UI学习系列
  8. android 开发 新建工程
  9. flutter包名,应用名称,图标,启动图片修改
  10. Android 彻底退出自己APP 并杀掉所有相关