android的数据库操作一般都在SQLiteOpenHelper类中,而SQLiteOpenHelper是一个抽象类,所以需要一个类来实现这个抽象类。这个类为DateBaseHelper。
DateBaseHelper作为一个访问SQLite的助手类,提供一下两个方面的功能
(1)getReadableDatabase(),getWriteableDatabase()可以获得SQLiteDatabase对象,通过该对象对数据库进行操作
(2)提供onCreate()和onUpgrade()两个回调函数,允许我们在创建数据库时,进行自己的操作
package com.yx.db;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class DateBaseHelper extends SQLiteOpenHelper {
 private static final int VERSION=2;//数据库的版本号
 //在SQLiteOpenHelper的子类中必须有该构造函数,
 //context为一个activity对象,name为表名,version为当前数据库的版本
 public DateBaseHelper(Context context, String name, CursorFactory factory,
   int version) {
  super(context, name, factory, version);
 }
 
 public DateBaseHelper(Context context, String name) {
  this(context,name,VERSION);
 }
 public DateBaseHelper(Context context, String name,int version) {
  this(context,name,null,version);
 }
 //该函数是在第一次创建数据库时执行,实际上是第一次得到SQLiteDatabase时,才会掉用的方法
 @Override
 public void onCreate(SQLiteDatabase db) {
  System.out.println("create a database");
  db.execSQL("create table user(id int,name varchar(20))");
 }
 @Override
 public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
  System.out.println("upgrade a  db");
}
}
为了方便先贴出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:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" 
    android:orientation="vertical"
    >
    <Button 
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/creatDB"
        android:text="创建数据库"
        />
    <Button 
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/updateDB"
        android:text="更新数据库"
        />
    <Button 
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/insert"
        android:text="增加"
        />
    <Button 
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/update"
        android:text="更新"
        />
    <Button 
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/query"
        android:text="查询"
        />
</LinearLayout>
下面是调用sqlite是方法的类。
package com.yx.sqlite;
import com.yx.db.DateBaseHelper;
import android.os.Bundle;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
public class MainActivity extends Activity {
//获取Button
 private Button creatDB;
 private Button updateDB;
 private Button insert;
 private Button update;
 private Button query;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  creatDB = (Button) findViewById(R.id.creatDB);
  updateDB = (Button) findViewById(R.id.updateDB);
  insert = (Button) findViewById(R.id.insert);
  update = (Button) findViewById(R.id.update);
  query = (Button) findViewById(R.id.query);
//给Button注册监听事件
  creatDB.setOnClickListener(new creatDBButtonListener());
  updateDB.setOnClickListener(new updateDBButtonListener());
  insert.setOnClickListener(new insertButtonListener());
  update.setOnClickListener(new updateButtonListener());
  query.setOnClickListener(new queryButtonListener());
 }
 @Override
 public boolean onCreateOptionsMenu(Menu menu) {
  // Inflate the menu; this adds items to the action bar if it is present.
  getMenuInflater().inflate(R.menu.main, menu);
  return true;
 }
//创建数据库
class creatDBButtonListener implements OnClickListener{
  @Override
  public void onClick(View v) {
//下面两句是为了获得数据库
   DateBaseHelper helper = new DateBaseHelper(MainActivity.this, "textDB2");
   //只有调用SQLiteDatabase的getReadableDatabase或getWriteableDatabase中的一个才可以创建数据库
   SQLiteDatabase db = helper.getReadableDatabase();
  }
  
 }
 
//更新数据库
 class updateDBButtonListener implements OnClickListener{
  @Override
  public void onClick(View v) {
   DateBaseHelper helper = new DateBaseHelper(MainActivity.this, "textDB2",2);
   //只有调用SQLiteDatabase的getReadableDatabase或getWriteableDatabase中的一个才可以创建数据库
   SQLiteDatabase db = helper.getReadableDatabase();
   
  }
  
 }
 //给数据库添加数据
 class insertButtonListener implements OnClickListener{
  @Override
  public void onClick(View v) {
   ContentValues values = new ContentValues();
   //向ContentValues对象插入键值对
   values.put("id", 1);
   values.put("name", "张三");
   DateBaseHelper helper = new DateBaseHelper(MainActivity.this, "textDB2",2);
   SQLiteDatabase db = helper.getWritableDatabase();
   db.insert("user", null, values);
  }
  
 }
//修改数据库的数据 
 class updateButtonListener implements OnClickListener{
  @Override
  public void onClick(View v) {
   DateBaseHelper helper = new DateBaseHelper(MainActivity.this, "textDB2",2);
   SQLiteDatabase db = helper.getWritableDatabase();
   ContentValues values = new ContentValues();
   values.put("name", "zhangsan");
   db.update("user", values, "id=?", new String[]{"1"});
  }
  
 }
 
//查询数据库的数据
 class queryButtonListener implements OnClickListener{
  @Override
  public void onClick(View v) {
   System.out.println("queryButtonListener");
   DateBaseHelper helper = new DateBaseHelper(MainActivity.this, "textDB2",2);
   SQLiteDatabase db = helper.getReadableDatabase();
   Cursor cursor = db.query( "user", new String[]{"id","name"}, "id=?", new String[]{"1"}, null, null, null);
   while(cursor.moveToNext()){
    String name = cursor.getString(cursor.getColumnIndex("name"));
    System.out.println("quary-->"+name);
   }
  }
  
 }
}
原文:http://blog.csdn.net/yuexin2/article/details/18848539