ListView与Sqlite数据库绑定步骤:

1.将Sqlite数据库的内容查询出来并放入数组列表中,形成ListView的数据源;

2.适配器绑定数据源,显示在ListView item中。

本文实现的ListView与Sqlite数据绑定的功能如下图-1

图-1 ListView与Sqlite数据绑定的功能界面

本例主要实现的是一个学生数据表(Sqlite数据库)与ListView控件绑定数据的功能。

数据库为user.db,学生表为student,学生表包含的字段有:id,username,birthday,image。

image放在android的资源文件内。初始化时,自动创建数据库,用户表并插入三条用户数据,以作为Listview的数据源。

通过SimpleAdapter适配器与ListView控件绑定。

关于ListView与SimpleAdapter数据绑定,以及Sqlite数据库的创建,表的创建,表的操作,在本博客中有所叙述,这里不再叙述。可以说本文是将ListView使用与Sqlite使用相结合的结果,只是有更多的细节需要注意。

除了绑定数据库,还增加一个ListView长按Item选项的事件操作,本例长按ListView数据选项后会弹出一个询问的对话框,询问是否删除当前选项的数据表的一条数据。实现Listview长按响应事件,需要实现OnCreateContextMenuListener类的方法。通过AdapterView.AdapterContextMenuInfo类获取选项的相应位置,也就是数据源的具体数据,获取选项位置后,可以提取相应选项的内容进而执行相关的操作。

图片添加如下图

1.类文件

ListView_SqliteActivity.java

[java] view
plain
copy

  1. package codyy.liuyong;
[java] view
plain
copy

  1. import java.util.ArrayList;
  2. import java.util.HashMap;
  3. import android.app.Activity;
  4. import android.app.AlertDialog;
  5. import android.content.ContentValues;
  6. import android.content.DialogInterface;
  7. import android.database.Cursor;
  8. import android.database.SQLException;
  9. import android.database.sqlite.SQLiteDatabase;
  10. import android.os.Bundle;
  11. import android.view.ContextMenu;
  12. import android.view.ContextMenu.ContextMenuInfo;
  13. import android.view.View;
  14. import android.view.View.OnCreateContextMenuListener;
  15. import android.widget.AdapterView;
  16. import android.widget.ListView;
  17. import android.widget.SimpleAdapter;
  18. import android.widget.Toast;
  19. public class ListView_SqliteActivity extends Activity {
  20. SQLiteDatabase mDb;
  21. SQLiteDatabaseDao dao;
  22. // 存储数据的数组列表
  23. ArrayList<HashMap<String, Object>> listData;
  24. // 适配器
  25. SimpleAdapter listItemAdapter;
  26. /** Called when the activity is first created. */
  27. @Override
  28. public void onCreate(Bundle savedInstanceState) {
  29. super.onCreate(savedInstanceState);
  30. setContentView(R.layout.main);
  31. dao = new SQLiteDatabaseDao();
  32. ListView list = (ListView) findViewById(R.id.list_items);
  33. listItemAdapter = new SimpleAdapter(ListView_SqliteActivity.this,
  34. listData,// 数据源
  35. R.layout.item,// ListItem的XML实现
  36. // 动态数组与ImageItem对应的子项
  37. new String[] { "image", "username", "birthday" },
  38. // ImageItem的XML文件里面的一个ImageView,两个TextView ID
  39. new int[] { R.id.image, R.id.username, R.id.birthday });
  40. list.setAdapter(listItemAdapter);
  41. list.setOnCreateContextMenuListener(listviewLongPress);
  42. }
  43. // 简单的数据库操作类
  44. class SQLiteDatabaseDao {
  45. public SQLiteDatabaseDao() {
  46. mDb = openOrCreateDatabase("users.db",
  47. SQLiteDatabase.CREATE_IF_NECESSARY, null);
  48. // 初始化创建表
  49. createTable(mDb, "student");
  50. // 初始化插入数据
  51. insert(mDb, "student");
  52. // 初始化获取所有数据表数据
  53. getAllData("student");
  54. }
  55. // 创建一个数据库
  56. public void createTable(SQLiteDatabase mDb, String table) {
  57. try {
  58. mDb.execSQL("create table if not exists "
  59. + table
  60. + " (id integer primary key autoincrement, "
  61. + "username text not null, birthday text not null,image text);");
  62. } catch (SQLException e) {
  63. Toast.makeText(getApplicationContext(), "数据表创建失败",
  64. Toast.LENGTH_LONG).show();
  65. }
  66. }
  67. // 插入数据
  68. public void insert(SQLiteDatabase mDb, String table) {
  69. // 初始化插入3条数据
  70. ContentValues values = new ContentValues();
  71. values.put("username", "LiMei");
  72. values.put("birthday", "Birthday:6-18");
  73. values.put("image", R.drawable.o);
  74. mDb.insert(table, null, values);
  75. values.put("username", "LinQiao");
  76. values.put("birthday", "Birthday:8-22");
  77. values.put("image", R.drawable.t);
  78. mDb.insert(table, null, values);
  79. values.put("username", "WiLee");
  80. values.put("birthday", "Birthday:9-12");
  81. values.put("image", R.drawable.f);
  82. mDb.insert(table, null, values);
  83. }
  84. // 查询所有数据
  85. public void getAllData(String table) {
  86. Cursor c = mDb.rawQuery("select * from " + table, null);
  87. int columnsSize = c.getColumnCount();
  88. listData = new ArrayList<HashMap<String, Object>>();
  89. // 获取表的内容
  90. while (c.moveToNext()) {
  91. HashMap<String, Object> map = new HashMap<String, Object>();
  92. for (int i = 0; i < columnsSize; i++) {
  93. map.put("id", c.getString(0));
  94. map.put("username", c.getString(1));
  95. map.put("birthday", c.getString(2));
  96. map.put("image", c.getString(3));
  97. }
  98. listData.add(map);
  99. }
  100. }
  101. // 删除一条数据
  102. public boolean delete(SQLiteDatabase mDb, String table, int id) {
  103. String whereClause = "id=?";
  104. String[] whereArgs = new String[] { String.valueOf(id) };
  105. try {
  106. mDb.delete(table, whereClause, whereArgs);
  107. } catch (SQLException e) {
  108. Toast.makeText(getApplicationContext(), "删除数据库失败",
  109. Toast.LENGTH_LONG).show();
  110. return false;
  111. }
  112. return true;
  113. }
  114. }
  115. // 长按事件响应
  116. OnCreateContextMenuListener listviewLongPress = new OnCreateContextMenuListener() {
  117. @Override
  118. public void onCreateContextMenu(ContextMenu menu, View v,
  119. ContextMenuInfo menuInfo) {
  120. // TODO Auto-generated method stub
  121. final AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo) menuInfo;
  122. new AlertDialog.Builder(ListView_SqliteActivity.this)
  123. /* 弹出窗口的最上头文字 */
  124. .setTitle("删除当前数据")
  125. /* 设置弹出窗口的图式 */
  126. .setIcon(android.R.drawable.ic_dialog_info)
  127. /* 设置弹出窗口的信息 */
  128. .setMessage("确定删除当前记录")
  129. .setPositiveButton("是",
  130. new DialogInterface.OnClickListener() {
  131. public void onClick(
  132. DialogInterface dialoginterface, int i) {
  133. // 获取位置索引
  134. int mListPos = info.position;
  135. // 获取对应HashMap数据内容
  136. HashMap<String, Object> map = listData
  137. .get(mListPos);
  138. // 获取id
  139. int id = Integer.valueOf((map.get("id")
  140. .toString()));
  141. // 获取数组具体值后,可以对数据进行相关的操作,例如更新数据
  142. if (dao.delete(mDb, "student", id)) {
  143. // 移除listData的数据
  144. listData.remove(mListPos);
  145. listItemAdapter.notifyDataSetChanged();
  146. }
  147. }
  148. })
  149. .setNegativeButton("否",
  150. new DialogInterface.OnClickListener() {
  151. public void onClick(
  152. DialogInterface dialoginterface, int i) {
  153. // 什么也没做
  154. }
  155. }).show();
  156. }
  157. };
  158. @Override
  159. public void finish() {
  160. // TODO Auto-generated method stub
  161. super.finish();
  162. mDb.close();
  163. }
  164. }

2.xml文件

main.xml

[html] view
plain
copy

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="vertical" >
  6. <ListView
  7. android:id="@+id/list_items"
  8. android:layout_width="wrap_content"
  9. android:layout_height="wrap_content"
  10. android:divider="#ffffff"
  11. android:dividerHeight="1dip" />
  12. </RelativeLayout>

item.xml

[html] view
plain
copy

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:id="@+id/RelativeLayout"
  4. android:layout_width="fill_parent"
  5. android:layout_height="wrap_content"
  6. android:paddingBottom="4dip"
  7. android:paddingLeft="12dip"
  8. android:paddingRight="12dip" >
  9. <ImageView
  10. android:id="@+id/image"
  11. android:layout_width="wrap_content"
  12. android:layout_height="wrap_content"
  13. android:layout_alignParentRight="true"
  14. android:paddingLeft="6dip"
  15. android:paddingTop="6dip" />
  16. <TextView
  17. android:id="@+id/username"
  18. android:layout_width="fill_parent"
  19. android:layout_height="wrap_content"
  20. android:paddingTop="6dip"
  21. android:textColor="#ccc"
  22. android:textSize="18dip" />
  23. <TextView
  24. android:id="@+id/birthday"
  25. android:layout_width="fill_parent"
  26. android:layout_height="wrap_content"
  27. android:layout_below="@+id/username"
  28. android:maxLines="2"
  29. android:paddingRight="20dip"
  30. android:textColor="#fff" />
  31. </RelativeLayout>

android实例 listview与sqlite数据绑定的更多相关文章

  1. 42.Android之ListView中ArrayAdapter简单学习

    今天学习下Android中ListView关于ArrayAdapter数据绑定, 废话少说直接上代码. 改下布局文件: <?xml version="1.0" encodin ...

  2. [android] 手机卫士黑名单功能(ListView结合SQLite增删改)

    修改界面,在顶部横条上增加一个添加按钮,点击打开一个自定义对话框,输入电话号码和拦截模式保存到数据库 自定义对话框看这篇http://www.cnblogs.com/taoshihan/p/53703 ...

  3. Android之ListView性能优化——一行代码绑定数据——万能适配器

    如下图,加入现在有一个这样的需求图,你会怎么做?作为一个初学者,之前我都是直接用SimpleAdapter结合一个Item的布局来实现的,感觉这样实现起来很方便(基本上一行代码就可以实现),而且也没有 ...

  4. android——自定义listView

    都知道微信主机面 有个界面会一行一一行的聊天记录,那个效果就可以用listview来实现(当然这只是其中的一种) listView是一种比较常见的组件它用来展示列的view,它是根据数据的长度来显示数 ...

  5. 45个android实例源码

    分享45个android实例源码,很好很强大http://www.apkbus.com/android-20978-1-1.html andriod闹钟源代码http://www.apkbus.com ...

  6. 分享45个android实例源码,很好很强大

    分享45个android实例源码,很好很强大 http://www.apkbus.com/android-20978-1-1.html 分享45个android实例源码,很好很强大http://www ...

  7. android学习笔记48——SQLite

    SQLite SQLite试试一个嵌入式的数据库引擎,专门用于资源有限的设备(如手机.PDA)上适量数据存取. SQLite支持绝大部分SQL92语法,同样允许开发者使用SQL语句操作数据库中的数据, ...

  8. Android的ListView

    ListView ListView 是一个控件,一个在垂直滚动的列表中显示条目的一个控件,这些条目的内容来自于一个ListAdapter. 一个简单的例子 布局文件里新增ListView <Li ...

  9. 【Android 应用开发】Android 数据存储 之 SQLite数据库详解

    . 作者 :万境绝尘 转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/19028665 . SQLiteDataBase示例程序下 ...

随机推荐

  1. 在C#中使用二叉树实时计算海量用户积分排名的实现

    从何说起 前些天和朋友讨论一个问题,他们的应用有几十万会员然后对应有积分,现在想做积分排名的需求,问有没有什么好方案.这个问题也算常见,很多地方都能看到,常规做法一般是数据定时跑批把计算结果到中间表然 ...

  2. 1037 在霍格沃茨找零钱 (20 分)C语言

    题目描述 如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 -- 就如海格告诉哈利的:"十七个银西可(Sickle)兑一个加隆(Galleon),二 十九个纳特(Knut)兑一个西可 ...

  3. 【原创】(十五)Linux内存管理之RMAP

    背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: Kernel版本: ...

  4. [ASP.NET Core 3框架揭秘] Options[1]: 配置选项的正确使用方式[上篇]

    依赖注入不仅是支撑整个ASP.NET Core框架的基石,也是开发ASP.NET Core应用采用的基本编程模式,所以依赖注入十分重要.依赖注入使我们可以将依赖的功能定义成服务,最终以一种松耦合的形式 ...

  5. 大数据框架开发基础之Sqoop(1) 入门

    Sqoop是一款开源的工具,主要用于在Hadoop(Hive)与传统的数据库(mysql.postgresql...)间进行数据的传递,可以将一个关系型数据库(例如 : MySQL ,Oracle , ...

  6. schedule of 2016-10-24~2016-10-30(Monday~Sunday)——1st semester of 2nd Grade

    2016/10/24 Monday forcus:find a way to try to recognize emotions in database2.0(see ppt Week 7) 1.pr ...

  7. CI框架获取post和get参数_CodeIgniter使用心得

    请参考:CI文档的输入类部分: $this->input->post()$this->input->get() -------------------------------- ...

  8. Go 每日一库之 go-homedir

    简介 今天我们来看一个很小,很实用的库go-homedir.顾名思义,go-homedir用来获取用户的主目录. 实际上,使用标准库os/user我们也可以得到这个信息: package main i ...

  9. .NET Core学习笔记(3)——async/await中的Exception处理

    在写了很多年.NET程序之后,年长的猿类在面对异步编程时,仍不时会犯下致命错误,乃至被拖出去杀了祭天.本篇就async/await中的Exception处理进行讨论,为种族的繁衍生息做出贡献……处理a ...

  10. SEATA 分布式事务入门DEMO

    Simple Extensible Autonomous Transacation Architecture,seata是简单的.可扩展.自主性高的分布式架构 SEATA Server Configu ...