Android开发手记(18) 数据存储三 SQLite存储数据
Android为数据存储提供了五种方式:
1、SharedPreferences
2、文件存储
3、SQLite数据库
4、ContentProvider
5、网络存储
SQLite 是以嵌入式为目的而设计的轻型数据库,运行起来占用的资源非常低,通常只需要几百K的内存就足够了。同时也具有非常好的兼容性,支持标准SQL语言。Android提供了对SQLite的支持,我们可以通过其来管理一些应用数据。
一、创建SQLite数据库和表
我们可以通过SQLiteDatabase.openOrCreateDatabase()来创建一个数据库实例。
SQLiteDatabase db = openOrCreateDatabase(dbName, MODE_PRIVATE, null); // openOrCreateDatabase(String name, int mode, CursorFactory factory) // 第一个参数为创建数据库的名称 // 第二个参数为创建数据库的权限,其权限同内部文件存储数据权限相同。默认为MODE_PRIVATE。 // 第三个参数为CursorFactory对象,用于查询时返回Cursor的子类对象;或者传入null使用默认的factory构造。
在创建表的时候,我们可以使用一条SQL语句来完成。
cmd = "CREATE TABLE IF NOT EXISTS " + tableName + " (name VARCHAR, passwd VARCHAR)"; db.execSQL(cmd);
这样,我们可以发现在“/data/data/[PACKAGE_NAME]/databases”目录下生成了一个“myDB.db”数据库文件。
完整代码:
import android.database.sqlite.SQLiteDatabase; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.widget.Button; public class MainActivity extends AppCompatActivity { private Button btnDB; private Button btnTable; private String dbName = "myDB"; private String cmd = ""; private SQLiteDatabase db; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btnDB = (Button)findViewById(R.id.btnDB); btnTable = (Button)findViewById(R.id.btnTable); btnDB.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { db = openOrCreateDatabase(dbName,MODE_PRIVATE,null); } }); btnTable.setOnClickListener(new View.OnClickListener() { String tableName = "User"; @Override public void onClick(View view) { cmd = "CREATE TABLE IF NOT EXISTS " + tableName + " (name VARCHAR, passwd VARCHAR)"; db.execSQL(cmd); } }); } }
二、添加、删除、修改
(1)SQL语句方法
cmd = "INSERT INTO " + tableName + " values ('Amy','123456')"; db.execSQL(cmd); cmd = "UPDATE " + tableName + " SET passwd='654321' WHERE name='AMY')"; db.execSQL(cmd); cmd = "DELETE FROM " + tableName + " WHERE name='Amy'"; db.execSQL(cmd);
(2)另一种方法
db.insert(String table, String nullColumnHack, ContentValues values); db.update(String table, Contentvalues values, String whereClause, String whereArgs); db.delete(String table, String whereClause, String whereArgs);
以上三个方法的第一个参数都是表示要操作的表名;insert中的第二个参数表示如果插入的数据每一列都为空的话,需要指定此行中某一列的名称,系统将此列设置为NULL,不至于出现错误;insert中的第三个参数是ContentValues类型的变量,是键值对组成的Map,key代表列名,value代表该列要插入的值;update的第二个参数也很类似,只不过它是更新该字段key为最新的value值,第三个参数whereClause表示WHERE表达式,比如“age > ? and age < ?”等,最后的whereArgs参数是占位符的实际参数值;delete方法的参数也是一样。
实例:
btnTable.setOnClickListener(new View.OnClickListener() { String tableName = "User"; @Override public void onClick(View view) { cmd = "CREATE TABLE IF NOT EXISTS " + tableName + " (name VARCHAR, passwd VARCHAR)"; db.execSQL(cmd); ContentValues cv = new ContentValues(); cv.put("name", "Amy"); cv.put("passwd", "123456"); db.insert(dbName, null, cv); // cmd = "INSERT INTO " + tableName + " values ('Amy','123456')"; // db.execSQL(cmd); cv = new ContentValues(); cv.put("passwd", "654321"); db.update(dbName, cv, "name=?", new String[]{"Amy"}); // cmd = "UPDATE " + tableName + " SET passwd='654321' WHERE name='AMY')"; // db.execSQL(cmd); db.delete(dbName, "name=?", new String[]{"Amy"}); // cmd = "DELETE FROM " + tableName + " WHERE name='Amy'"; // db.execSQL(cmd); } });
三、数据库查询
对数据库的查询可以通过db.query()来实现,query方法一般包含8个参数:
db.query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit); // table为查询表的名称 // columns为查询的字段名 // selection为查询的条件 // selectionArgs为查询条件的值 // groupBy为分组字段值 // having为分组后筛选条件 // orderBy为排序字段名 // limit为查询结果返回记录条数
查询的的结果通过Cursor返回。代表数据集的游标。
Cursor cursor = db.query(tableName, null, null, null, null, null, null); String str = ""; if(cursor.getCount()!=0){ // 查询符合条件的记录个数 cursor.moveToFirst(); // 移动到第一个记录 for(int i=0; i<cursor.getCount();i++){ str += cursor.getString(0)+" "+cursor.getString(1)+"\n"; cursor.moveToNext(); // 移动到下一个记录 } } new AlertDialog.Builder(MainActivity.this).setTitle("Query") .setMessage(str).setNegativeButton("OK",null).show();
四、SQLiteOpenHelper
除了常规的管理方法之外,Android SDK还提供了另外一种管理数据库的方法,SQLiteOpenHelper。它提供了一套自动执行的机制来创建、更新、打开数据库。
首先,我们继承SQLiteOpenHelper类,创建MyDBHelper类。
public class MyDBHelper extends SQLiteOpenHelper { private String tableName = "User"; public MyDBHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) { super(context, name, factory, version); } public void onCreate(SQLiteDatabase db) { String cmd = "CREATE TABLE IF NOT EXISTS " + tableName + " (name VARCHAR, passwd VARCHAR)"; db.execSQL(cmd); } public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String cmd = "UPDATE " + tableName + " SET passwd='654321' WHERE name='AMY')"; db.execSQL(cmd); } public String showTable(){ SQLiteDatabase db = this.getReadableDatabase(); Cursor cursor = db.query(tableName, null, null, null, null, null, null); String str = ""; if(cursor.getCount()!=0){ // 查询符合条件的记录个数 cursor.moveToFirst(); // 移动到第一个记录 for(int i=0; i<cursor.getCount();i++){ str += cursor.getString(0)+" "+cursor.getString(1)+"\n"; cursor.moveToNext(); // 移动到下一个记录 } } return str; } }
然后,我们便可以在MainActivity内使用我们定义的SQLiteOpenHelper类的方法。
btnShow = (Button) findViewById(R.id.btnShow); btnShow.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { dbHelper = new MyDBHelper(MainActivity.this, dbName, null, 1); new AlertDialog.Builder(MainActivity.this).setTitle("MyDBHelper") .setMessage(dbHelper.showTable()).setNegativeButton("OK", null).show(); } });
完整代码如下:
MainActivity.java
import android.app.AlertDialog; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.widget.Button; public class MainActivity extends AppCompatActivity { private Button btnShow; private String dbName = "myDB"; private MyDBHelper dbHelper; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btnShow = (Button) findViewById(R.id.btnShow); btnShow.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { dbHelper = new MyDBHelper(MainActivity.this, dbName, null, 1); new AlertDialog.Builder(MainActivity.this).setTitle("MyDBHelper") .setMessage(dbHelper.showTable()).setNegativeButton("OK", null).show(); } }); } }
MyDBHelper.java
import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; public class MyDBHelper extends SQLiteOpenHelper { private String tableName = "User"; public MyDBHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) { super(context, name, factory, version); } public void onCreate(SQLiteDatabase db) { String cmd = "CREATE TABLE IF NOT EXISTS " + tableName + " (name VARCHAR, passwd VARCHAR)"; db.execSQL(cmd); } public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String cmd = "UPDATE " + tableName + " SET passwd='654321' WHERE name='AMY')"; db.execSQL(cmd); } public String showTable(){ SQLiteDatabase db = this.getReadableDatabase(); Cursor cursor = db.query(tableName, null, null, null, null, null, null); String str = ""; if(cursor.getCount()!=0){ // 查询符合条件的记录个数 cursor.moveToFirst(); // 移动到第一个记录 for(int i=0; i<cursor.getCount();i++){ str += cursor.getString(0)+" "+cursor.getString(1)+"\n"; cursor.moveToNext(); // 移动到下一个记录 } } return str; } }