`

android SQLiteOpenHelper使用示例

阅读更多

我们大家都知道Android平台提供给我们一个数据库辅助类来创建或打开数据库,这个辅助类继承自SQLiteOpenHelper类,在该类的构造器中,调用Context中的方法创建并打开一个指定名称的数据库对象。继承和扩展SQLiteOpenHelper类主要做的工作就是重写以下两个方法。

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) {
}

}

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 SQLiteOpenHelper 数据库简单应用

    本篇文章将深入探讨如何在Android中使用SQLiteOpenHelper进行数据库的简单应用。 首先,SQLiteOpenHelper有两个关键方法:`onCreate()` 和 `onUpgrade()`。`onCreate()` 方法在数据库首次创建时被调用,用于执行...

    基于Android SQLiteOpenHelper && CRUD 的使用

    - 示例中的`PersonService`类封装了对`person`表的CRUD操作,使用`DBOpenHelper`实例创建数据库连接,并提供了保存、删除、更新和查找个人数据的方法。 通过以上介绍,我们可以看到Android开发中如何利用`...

    SQLiteOpenHelper类的onUpgrade方法的作用

    在深入探讨`SQLiteOpenHelper`类中的`onUpgrade`方法之前,我们先来了解下`SQLiteOpenHelper`类在Android开发中的重要性。`SQLiteOpenHelper`是Android SDK提供的一个辅助类,用于帮助开发者创建和管理应用程序中的...

    android app 示例 SQLiteOpenHelper 实现数据操作

    在这个示例中,我们将深入探讨如何使用SQLiteOpenHelper进行数据操作。 SQLiteOpenHelper主要有两个关键方法:`onCreate()` 和 `onUpgrade()`。`onCreate()` 方法在数据库首次创建时被调用,用于执行初始化操作,...

    android 中 SQLiteOpenHelper的封装使用详解

    "Android 中 SQLiteOpenHelper 的封装使用详解" SQLiteOpenHelper 是 Android 中一个非常重要的数据库帮助器类,它提供了对 SQLite 数据库的访问和管理功能。下面我们将详细介绍 SQLiteOpenHelper 的封装使用详解。...

    Android 数据库 SQlite 范例 SQLiteOpenHelper

    这篇教程将深入探讨如何使用SQLiteOpenHelper进行数据库操作,并结合ListView展示数据,同时也会讲解Menu键的使用。 首先,让我们了解SQLiteOpenHelper的主要方法。`onCreate()`方法会在数据库首次创建时被调用,...

    基于Android SQLiteOpenHelper CRUD 的使用

    SQLiteOpenHelper是Android SDK提供的一种方便管理SQLite数据库的类,它主要用于数据库的创建、升级以及版本管理。下面我们将详细讲解如何基于SQLiteOpenHelper进行CRUD(Create、Read、Update、Delete)操作。 ...

    android 项目利用SQLiteOpenHelper创建数据库文件Demo

    在这个“android项目利用SQLiteOpenHelper创建数据库文件Demo”中,我们将深入探讨如何在Android应用中有效地使用SQLiteOpenHelper。 首先,我们需要了解SQLiteOpenHelper的基本结构。一个典型的SQLiteOpenHelper...

    SQLiteOpenHelper

    通过学习和理解这个例子,你应该能够熟练地在Android应用中使用SQLiteOpenHelper进行数据库操作。确保正确处理数据库的版本管理,以适应应用程序的迭代更新,同时也要注意线程安全问题,尤其是在多线程环境中操作...

    SqliteOpenHelper

    总结起来,这个项目是一个简单的Android应用,使用`SqliteOpenHelper`来管理SQLite数据库。`MainActivity`负责与用户交互,而`MyDbHelper`处理所有与数据库相关的任务。通过学习这个项目,开发者可以了解如何在...

    android上面的sqlite使用例子

    下面我们将深入探讨如何在Android上使用SQLite,以及通过提供的压缩包文件中的例子来学习相关知识。 首先,Android SDK提供了`SQLiteOpenHelper`类,它是处理SQLite数据库的主要入口点。这个类帮助我们创建、升级和...

    Android中使用SQLite示例

    以下是对Android中使用SQLite进行详细讲解: 1. **SQLite简介** SQLite是一个开源、嵌入式的关系型数据库,支持SQL标准。在Android中,每个应用程序都可以拥有自己的SQLite数据库,并且无需额外的服务器进程。它的...

    Pro-Android-3 BookProvider SQLiteOpenHelper

    《Pro-Android-3 BookProvider SQLiteOpenHelper》是关于Android应用开发的一本专业书籍,主要探讨了如何在Android系统中利用`BookProvider`和`SQLiteOpenHelper`进行数据存储和管理。`BookProvider`是自定义的内容...

    android 经典代码例子

    在这个压缩包中,我们可能找到了多个有关Android编程的示例项目或者代码片段。下面,我将详细讲解一些Android开发中的重要知识点。 1. **Activity**:Activity是Android应用的基本组件,代表用户界面的一个屏幕。它...

    SuperDB,演示使用SQLiteOpenHelper继承子类操作数据库例子

    在Android应用开发中,数据库是存储和...通过查看和运行这些代码,你可以更深入地理解如何在Android应用中使用SQLiteOpenHelper进行数据库操作。记住,良好的数据库设计和合理的数据操作能有效提升应用的稳定性和效率。

    SQLiteOpenHelper.zip

    本项目"SQLiteOpenHelper.zip"提供了一个简单的SQLiteOpenHelper实现,针对两个字符串字段进行CRUD(Create、Read、Update、Delete)操作的示例。 首先,我们来看`SQLiteOpenHelper`类的主要方法: 1. `onCreate...

    SQLiteOpenHelper数据库

    SQLiteOpenHelper是Android开发中用于操作SQLite数据库的一个关键类,它主要负责...在DatabaseTest这个示例中,你可以找到一个简单的SQLiteOpenHelper实现,通过分析代码,初学者可以快速掌握数据库操作的基本技巧。

    android SQLite数据库基础使用例子

    在Android开发中,SQLite是一个非常重要的组成部分,它是一个轻量级的、开源的、嵌入式的...对于初学者来说,这是一个很好的学习资源,通过分析和运行这个示例,你可以更深入地理解Android中SQLite数据库的基本使用。

    android之sqlite实现增删改查

    "Android之SQLite实现增删改查" Android平台中,SQLite是一种轻量级的关系型数据库,广泛应用于移动应用开发中。...通过这个示例代码,我们可以更好地理解SQLite数据库的使用和Android平台中的数据库编程技术。

Global site tag (gtag.js) - Google Analytics