首页 > 移动平台 > 详细

android数据库sqlite

时间:2014-01-29 02:17:25      阅读:423      评论:0      收藏:0      [点我收藏+]

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

 

 

 

android数据库sqlite

原文:http://blog.csdn.net/yuexin2/article/details/18848539

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!