热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Android利用listview控件操作SQLite数据库实例

我们利用SQLiteOpenHelper类建立一个数据库,并写好增、删、查等方法,通过SimpleCursorAdapter连接listview实现数据库的增加、查询以及长按删除的功能。

在本实例中,首先我们利用SQLiteOpenHelper类建立一个数据库,并写好增、删、查等方法,通过SimpleCursorAdapter连接listview实现数据库的增加、查询以及长按删除的功能。

首先,我们先认识一下什么是SQLiteOpenHelper类。

Android为了操作SQlite数据库,提供了SQLiteDatabase类,其内封装了insert 、delete、update 、query 、执行SQL命令等操作。同时又为SQLiteDatabase提供了一个辅助类,SQLiteOpenHelper。它提供了两个重要的方法,分别是:

onCreate(SQLiteDatabase db):用户初次使用软件时生成数据库,一旦数据库存在则不会调用此方法。函数是在第一次创建数据库的时候执行的,仅仅生成DataBaseHelper对(SQLiteOpenHelper类型)的时候是不会调用该函数的,而只有当调用DataBaseHelper对象的getReadableDataBase时或者是调用了getWritableDataBase时,如果是第一次创建数据库,那么就一定会调用onCreate()函数。

onUpgrade(SQLiteDatabase db,int oldVersion,int vewVersion):用于升级软件时更新数据库表结构,如增加表、列字段等操作。

实现了这两个方法,就可以用它的getWritableDatabase()和getReadableDatabase()来获得数据库(SQLiteDatabase 对象)。

如果用户需要升级数据库表结构,需要主动调用onUpgrade(SQLiteDatabase db,int oldVersion,int vewVersion),传入一个新的版本的号。

建立一个新数据库的代码如下:

package com.example.listview_sqlite_xu;

import android.content.Context;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteDatabase.CursorFactory;

import android.database.sqlite.SQLiteOpenHelper;

public class NewsSearchDatabaseHelper extends SQLiteOpenHelper {

final String SQL_CREATE_TABLE = "create table news_table (" +

"_id integer primary key autoincrement, " +

"news_tittle varchar(50), " +

"news_content varchar(5000))";
public NewsSearchDatabaseHelper(Context context, String name, int version) {
    super(context, name, null, version);
  }

  @Override
  public void onCreate(SQLiteDatabase db) {
    db.execSQL(SQL_CREATE_TABLE);
  }
  @Override
  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    System.out.println("call update");
  }   
}

接下来我们建立MainActivity:

package com.example.listview_sqlite_xu;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;

import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.View;
import android.view.View.OnCreateContextMenuListener;
import android.widget.AdapterView;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
import android.widget.Toast;

public class MainActivity extends Activity {

  private NewsSearchDatabaseHelper helper;  //数据库帮助类
  private EditText et_tittle;          //输入新闻标题
  private EditText et_content;        //输入新闻内容
  private ListView listView;                  //显示新闻列表
  ArrayList> listData; //  key-value

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    helper = new NewsSearchDatabaseHelper(getApplicationContext(), "news", 1);       //创建一个名为“news”的数据库

    //初始化控件
    et_tittle = (EditText) findViewById(R.id.et_news_tittle);
    et_cOntent= (EditText) findViewById(R.id.et_news_content);
    listView = (ListView) findViewById(R.id.lv_news);
    listView.setOnCreateContextMenuListener(listviewLongPress); 
      // 设置长按事件 


  }

  /*
   * 按钮点击事件
   * 通过判断被点击的组件, 执行不同的操作
   */
  public void onClick(View view) {
    int id = view.getId();
    if(id==R.id.bt_add) 
     insertNews();

    else if(id== R.id.bt_query)
        queryNews();

    }

  /*
   * 刷新数据库列表显示
   * 1. 关联SimpleCursorAdapter与数据库表, 获取数据库表中的最新数据
   * 2. 将最新的SimpleCursorAdapter设置给ListView
   */
  private void inflateListView(Cursor cursor) {
  SimpleCursorAdapter cursorAdapter = new SimpleCursorAdapter(getApplicationContext(), R.layout.item, cursor, new String[]{"news_tittle", "news_content"}, new int[]{R.id.tittle, R.id.content},1);

    listView.setAdapter(cursorAdapter);
  }

  /*
   * 插入新闻数据
   * 1. 从EditText组件中获取新闻的标题 和 新闻内容
   * 2. 获取数据库并从将 新闻标题 和 内容 插入到数据库中
   * 3. 重新查询数据库 获得Cursor对象
   * 4. 根据cursor对象创建SimpleCursorAdapter对象
   * 5. 将SimpleCursorAdapter设置给ListView, 显示新闻列表
   */
  private void insertNews() {
    String tittle = et_tittle.getText().toString();
    String cOntent= et_content.getText().toString();

    helper.getReadableDatabase().execSQL("insert into news_table values(null, ?, ?)", new String[]{tittle, content});

    Cursor cursor = helper.getReadableDatabase().rawQuery("select * from news_table", null);
    inflateListView(cursor);      //刷新listview
  }

  /*
   * 删除新闻数据
   * 根据_id删除指定数据,并进行刷新
   */
  private boolean deleteNews(int _id) {
     String whereClause = "_id=?"; 
     String[] whereArgs = new String[] { String.valueOf(_id) }; 
     try{
     helper.getReadableDatabase().delete("news_table", whereClause,whereArgs);
     Cursor cursor = helper.getWritableDatabase().rawQuery("select * from news_table", null);
     inflateListView(cursor);
     }catch (SQLException e) { 
       Toast.makeText(getApplicationContext(), "删除数据库失败", 
           Toast.LENGTH_LONG).show(); 
       return false; 
     } 
     return true; 
   } 



  //长按listview删除item   
  OnCreateContextMenuListener listviewLOngPress= new OnCreateContextMenuListener() { 
     public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) { 
        final AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo) menuInfo; 
        new AlertDialog.Builder(MainActivity.this) 
            // 弹出窗口的最上头文字  
            .setTitle("删除当前数据") 
             //设置弹出窗口的图式  
            .setIcon(android.R.drawable.ic_dialog_info) 
            // 设置弹出窗口的信息  
            .setMessage("确定删除当前记录") 
            .setPositiveButton("是", 
             new DialogInterface.OnClickListener() { 
             public void onClick( DialogInterface dialoginterface, int i) { 
                    // 获取位置索引 
            int mListPos = info.position; 
                    // 将listview中所有的数据都传入hashmap-listData中
            Cursor c = helper.getReadableDatabase().rawQuery("select * from news_table", null);
            int columnsSize = c.getColumnCount();
            listData = new ArrayList>();
             while (c.moveToNext()) { 
            HashMap map = new HashMap(); 
             for (int j = 0; j  map = listData .get(mListPos); 
              // 获取id 
              int id = Integer.valueOf((map.get("_id").toString())); 
             deleteNews(id); 
               // 移除数据   
             } 
             } 
           ) 
        .setNegativeButton("否", 
          new DialogInterface.OnClickListener() { 
           public void onClick( 
             DialogInterface dialoginterface, int i) { 
                    // 什么也没做 

                  } 
                }).show(); 
      } 
    };





  /*
   * 查询新闻
   * 1. 获取要查询的新闻标题 和 新闻内容
   * 2. 查询数据库 获取 Cursor, 并将Cursor转化为List>类型的集合
   * 3. 将集合放入bundle, Intent开启另一个Activity, 将bundle放入intent对象, 跳转Activity
   * 
   */
  private void queryNews() {
    String tittle = et_tittle.getText().toString();
    String cOntent= et_content.getText().toString();

    Cursor cursor = helper.getReadableDatabase().rawQuery(
        "select * from news_table where news_tittle like ? and news_content like ?", 
        new String[]{"%" + tittle + "%", "%" + content + "%"});

    Bundle bundle = new Bundle();
    bundle.putSerializable("news", cursor2list(cursor));
    Intent intent = new Intent(this, SearchResultActivity.class);
    intent.putExtras(bundle);
    startActivity(intent);  
  }

  /*
   * 返回一个ArrayList集合, 这个集合中每个元素是一个Map集合, 每个Map集合有两个元素
   * 解析Cursor对象 : 
   * 1. cursor光标向下移动一格; 
   * 2. 创建一个HashMap对象
   * 3. 使用 cursor.getString(列标号)获取该行中某列值, 将这个值放入map中
   * 4. 将Map对象放入
   */
  private ArrayList> cursor2list(Cursor cursor) {
    ArrayList> list = new ArrayList>();

    //遍历Cursor
    while(cursor.moveToNext()){
      Map map = new HashMap();
      map.put("tittle", cursor.getString(1));
      map.put("content", cursor.getString(2));
      list.add(map);
    }
    return list;
  }
  @Override
  protected void onDestroy() {
    super.onDestroy();
    //释放数据库资源
    if(helper !=null)
      helper.close();
  }
}

新建一个Activity用来显示查询的结果:

package com.example.listview_sqlite_xu;

import java.util.List;
import java.util.Map;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.widget.ListView;
import android.widget.SimpleAdapter;

public class SearchResultActivity extends Activity {

  private ListView listView;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    //设置布局文件
    setContentView(R.layout.news_search_result);
    //初始化组件
    listView = (ListView) findViewById(R.id.lv_search_result);
    //获取跳转到该Activity的intent对象
    Intent intent = getIntent();
    //获取Intent对象所携带的数据
    Bundle bundle = intent.getExtras();
    //从Bundle中取出List>数据
    @SuppressWarnings("unchecked")
    List> list = (List>)bundle.getSerializable("news");

    SimpleAdapter adapter = new SimpleAdapter(
        getApplicationContext(),   //上下文对象
        list,             //数据源
        R.layout.item,         //List显示布局
        new String[]{"tittle", "content"}, //List中map的键值
        new int[]{R.id.tittle, R.id.content});  //填充到的布局文件

    listView.setAdapter(adapter);
  }

}

main_activity的布局文件



  

  

  

  

  
    

查询结果页面布局文件:

<&#63;xml version="1.0" encoding="utf-8"&#63;>


  



以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • r2dbc配置多数据源
    R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
author-avatar
mobiledu2502885243
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有