浅谈---android SQLiteOpenHelper
2015-09-07 09:56
555 查看
我们大家都知道Android平台提供给我们一个数据库辅助类来创建或打开数据库,这个辅助类继承自SQLiteOpenHelper类,在该类的构造器中,调用Context中的方法创建并打开一个指定名称的数据库对象。继承和扩展SQLiteOpenHelper类主要做的工作就是重写以下两个方法。
SQLiteOpenHelper 类的基本用法是:当需要创建或打开一个数据库并获得数据库对象时,首先根据指定的文件名创建一个辅助对象,然后调用该对象的getWritableDatabase 或 getReadableDatabase方法 获得SQLiteDatabase 对象。
调用getReadableDatabase 方法返回的并不总是只读数据库对象,一般来说该方法和getWriteableDatabase 方法的返回情况相同,只有在数据库仅开放只读权限或磁盘已满时才会返回一个只读的数据库对象。
下面通过一个简单的小例子说明SQLiteOpenDatabase的用法,其中包括创建数据库、插入数据、更新 、查询等等,我们将查询后获取到的数据显示到TextView上,看一下运行后的效果。
MySQLiteHelper
Java代码 收藏代码
package xiaohang.zhimeng;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
public class MySQLiteHelper extends SQLiteOpenHelper{
//调用父类构造器
public MySQLiteHelper(Context context, String name, CursorFactory factory,
int version) {
super(context, name, factory, version);
}
}
Activity01
Java代码 收藏代码
package xiaohang.zhimeng;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.graphics.Color;
import android.os.Bundle;
import android.widget.TextView;
public class Activity01 extends Activity {
MySQLiteHelper myHelper;
TextView tv;
}
onCreate(SQLiteDatabase db) : 当数据库被首次创建时执行该方法,一般将创建表等初始化操作在该方法中执行。 onUpgrade(SQLiteDatabse dv, int oldVersion,int new Version):当打开数据库时传入的版本号与当前的版本号不同时会调用该方法。 除了上述两个必须要实现的方法外,还可以选择性地实现onOpen 方法,该方法会在每次打开数据库时被调用。
SQLiteOpenHelper 类的基本用法是:当需要创建或打开一个数据库并获得数据库对象时,首先根据指定的文件名创建一个辅助对象,然后调用该对象的getWritableDatabase 或 getReadableDatabase方法 获得SQLiteDatabase 对象。
调用getReadableDatabase 方法返回的并不总是只读数据库对象,一般来说该方法和getWriteableDatabase 方法的返回情况相同,只有在数据库仅开放只读权限或磁盘已满时才会返回一个只读的数据库对象。
下面通过一个简单的小例子说明SQLiteOpenDatabase的用法,其中包括创建数据库、插入数据、更新 、查询等等,我们将查询后获取到的数据显示到TextView上,看一下运行后的效果。
MySQLiteHelper
Java代码 收藏代码
package xiaohang.zhimeng;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
public class MySQLiteHelper extends SQLiteOpenHelper{
//调用父类构造器
public MySQLiteHelper(Context context, String name, CursorFactory factory,
int version) {
super(context, name, factory, version);
}
/** * 当数据库首次创建时执行该方法,一般将创建表等初始化操作放在该方法中执行. * 重写onCreate方法,调用execSQL方法创建表 * */ @Override public void onCreate(SQLiteDatabase db) { db.execSQL("create table if not exists hero_info(" + "id integer primary key," + "name varchar," + "level integer)"); } //当打开数据库时传入的版本号与当前的版本号不同时会调用该方法 @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { }
}
Activity01
Java代码 收藏代码
package xiaohang.zhimeng;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.graphics.Color;
import android.os.Bundle;
import android.widget.TextView;
public class Activity01 extends Activity {
MySQLiteHelper myHelper;
TextView tv;
@Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); tv = (TextView)findViewById(R.id.tv); //创建MySQLiteOpenHelper辅助类对象 myHelper = new MySQLiteHelper(this, "my.db", null, 1); //向数据库中插入和更新数据 insertAndUpdateData(myHelper); //查询数据 String result = queryData(myHelper); tv.setTextColor(Color.RED); tv.setTextSize(20.0f); tv.setText("名字\t等级\n"+result); } //向数据库中插入和更新数据 public void insertAndUpdateData(MySQLiteHelper myHelper){ //获取数据库对象 SQLiteDatabase db = myHelper.getWritableDatabase(); //使用execSQL方法向表中插入数据 db.execSQL("insert into hero_info(name,level) values('bb',0)"); //使用insert方法向表中插入数据 ContentValues values = new ContentValues(); values.put("name", "xh"); values.put("level", 5); //调用方法插入数据 db.insert("hero_info", "id", values); //使用update方法更新表中的数据 //清空ContentValues对象 values.clear(); values.put("name", "xh"); values.put("level", 10); //更新xh的level 为10 db.update("hero_info", values, "level = 5", null); //关闭SQLiteDatabase对象 db.close(); } //从数据库中查询数据 public String queryData(MySQLiteHelper myHelper){ String result = ""; //获得数据库对象 SQLiteDatabase db = myHelper.getReadableDatabase(); //查询表中的数据 Cursor cursor = db.query("hero_info", null, null, null, null, null, "id asc"); //获取name列的索引 int nameIndex = cursor.getColumnIndex("name"); //获取level列的索引 int levelIndex = cursor.getColumnIndex("level"); for (cursor.moveToFirst();!(cursor.isAfterLast());cursor.moveToNext()) { result = result + cursor.getString(nameIndex)+ "\t\t"; result = result + cursor.getInt(levelIndex)+" \n"; } cursor.close();//关闭结果集 db.close();//关闭数据库对象 return result; } @Override protected void onDestroy() { SQLiteDatabase db = myHelper.getWritableDatabase();//获取数据库对象 //删除hero_info表中所有的数据 传入1 表示删除所有行------>点击back按钮 db.delete("hero_info", "1", null); super.onDestroy(); }
}
相关文章推荐
- android去掉标题方法
- android 自定义ViewSwipeBackHelper,实现左滑结束Activity
- android 自定义ViewSwipeBackHelper,实现左滑结束Activity
- 我的第一个PhoneGap程序(Android)
- android登录界面点击返回键时的处理
- Android Studio 中提示 Private field ‘minute’ is assigned but never accessed 的原因
- android动画:头像在两个界面的移动效果
- Android闹钟 AlarmManager的使用
- android 加载本地联系人实现方法
- 【Android】2015.09.04 第一行代码 Day4 Count:6
- android权限管理, API劫持, xposed, xprivacy
- android studio gradle project sync failed,和android studio Error:Unable to start the daemon process问题
- Android Weight 使用 详解
- android spinner 调用onItemSelectedListener的思考
- Android 源码下载编译 FAQ
- Qt的前景如何?Qt for Android 好吗?
- Android提供的LruCache类简介
- Android 可拖动进度条:SeekBar之自定义进度条
- Android 开发环境下载地址 -- 百度网盘 adt-bundle android-studio sdk adt 下载
- Android中Fragment碎片解析