android数据库sqlite

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

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用SQLiteOpenHelper类来创建和管理SQLite数据库,然后使用Cursor类来查询数据库。最后将查询结果加入到ListView中显示即可。需要注意的是,需要自定义Adapter来适配ListView和Cursor之间的数据。 ### 回答2: Android 数据库 SQLiteAndroid 平台上的一个轻量级数据库,它没有独立的服务进程,完全由 Android 应用程序管理,运行在应用程序进程的主线程中,可以存储小型数据量。而 ListView 是一种常见的列表布局,可以用于展示一系列数据。 将 SQLite 查询结果显示到 ListView 中,我们需要进行以下步骤: 1.定义 SQLite 数据库Android 项目中,我们通常使用 SQLiteOpenHelper 来管理 SQLite 数据库。我们首先需要在项目中定义一个 SQLiteOpenHelper 类,它负责创建和更新 SQLite 数据库: ``` public class MyDatabaseHelper extends SQLiteOpenHelper { private static final String DATABASE_NAME = "myDatabase.db"; private static final int DATABASE_VERSION = 1; public MyDatabaseHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { // 创建表 db.execSQL("create table user (_id integer primary key autoincrement, name text, age integer)"); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // 更新表 db.execSQL("drop table if exists user"); onCreate(db); } } ``` 以上代码创建了一个名为 myDatabase.db 版本号为 1 的数据库,其中包含一个名为 user 的表,表中包含 _id、name 和 age 三个字段。 2.插入数据 接着我们需要向数据库中插入一些数据: ``` private void insertData() { SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("name", "Tom"); values.put("age", 20); db.insert("user", null, values); values.clear(); values.put("name", "Jerry"); values.put("age", 21); db.insert("user", null, values); } ``` 以上代码向 user 表中插入了两条数据。 3.查询数据并显示到 ListView 中 接下来,我们需要从 SQLite 数据库中查询数据,并且将查询结果显示到 ListView 中: ``` private void queryData() { SQLiteDatabase db = dbHelper.getReadableDatabase(); Cursor cursor = db.query("user", null, null, null, null, null, null); List<Map<String, Object>> list = new ArrayList<>(); while(cursor.moveToNext()) { Map<String, Object> map = new HashMap<>(); map.put("name", cursor.getString(cursor.getColumnIndex("name"))); map.put("age", cursor.getInt(cursor.getColumnIndex("age"))); list.add(map); } cursor.close(); SimpleAdapter adapter = new SimpleAdapter(this, list, android.R.layout.simple_list_item_2, new String[] {"name", "age"}, new int[] {android.R.id.text1, android.R.id.text2}); listView.setAdapter(adapter); } ``` 以上代码首先从 user 表中查询所有数据,将查询结果保存到 list 中。逐个遍历查询结果,将每一行数据封装成一个 Map 对象,再将其添加到 list 中。最后将 list 中的数据显示到 ListView 中。 至此,我们已经完成了将 SQLite 查询结果显示到 ListView 中的整个过程。关键是对 SQLiteOpenHelper、ContentValues、Cursor、SimpleAdapter 等类的使用,需要程序员对 Android 开发中常用的类有深入的了解。 ### 回答3: Android开发中,SQLite数据库是一种非常常见的数据存储方式。在应用程序中查询数据库并把数据显示到ListView中是Android开发中的基本操作之一,其实现过程如下: 1.建立数据库 SQLiteOpenHelper是一个用于管理数据库的帮助类。我们可以在该类中定义数据库的创建和更新。在该类中创建数据库表和进行表结构的修改。 2.进行数据库查询 要访问和查询数据库,需要使用可读数据库对象。我们可以利用SQLiteOpenHelper类的getReadableDatabase()方法获取可读数据库对象。然后执行SQL查询。 3.创建ListView列表布局 创建一个ListView对象,在通过SimpleAdapter适配器将查询到的数据绑定到ListView中。SimpleAdapter是一个适配器类,用于将数据库查询结果转换为列表视图中的数据项。我们可以将其实例化,并通过setAdapter()方法设置给ListView对象。 4.获取列表中的点击事件 当用户点击ListView中的某个数据项时,需要获取该操作并执行相应操作。为ListView添加setOnItemClickListener()方法即可监听用户操作。 5.完善UI界面 根据需要对ListView界面进行美化,并添加数据更新、删除等操作的实现。 总之,通过SQLiteOpenHelper和SimpleAdapter的帮助,我们可以轻松地将SQLite数据库中的数据查询并显示到ListView中。这种基本操作在Android应用程序开发中非常常见,是开发Android数据库应用程序的关键技能之一。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值