Android SQLite事务处理结合Listview列表显示功能示例

本文实例讲述了Android SQLite事务处理结合Listview列表显示功能。分享给大家供大家参考,具体如下:

前面的文章里介绍过事务的特点如原子性,隔离性,一致性,持久性。下面就结合Android的sqlite来说下,这次的文章里会把listview也结合起来用。实际上android里的事务和我们数据库里的是一样的。也是开启事务,操作,提交事务。如果出现问题就回滚。

public void Transaction(){ SQLiteDatabase database=db.getReadableDatabase(); database.beginTransaction(); //开启事务 try{ String sql1="update student set username='lili' where userid=2"; String sql2="update student set username='lucy' where userid=3"; database.execSQL(sql1); database.execSQL(sql2); database.setTransactionSuccessful(); //设置事务的状态,这句不写事务就会回滚 }finally{ database.endTransaction(); //结束事务 } }

上面这段代码就是一个简单的事务操作,需要注意的就是要捕获异常,这样事务就会被结束掉可以节约数据库资源。

事务的操作就是这样,下面就介绍下listview的使用,我们理解成列表就可以了。界面如下

我们可以把这个界面拆成2个,主界面就只有“用户id”,“用户名”,“用户住址”也就是列表的头,主界面如下

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="wrap_content" android:layout_height="wrap_content"> <TextView android:layout_width="60dip" android:layout_height="wrap_content" android:text="用户id" /> <TextView android:layout_width="60dip" android:layout_height="wrap_content" android:text="用户名" /> <TextView android:layout_width="60dip" android:layout_height="wrap_content" android:text="用户住址" /> </LinearLayout> <ListView android:layout_width="fill_parent" android:layout_height="wrap_content" android:id="@+id/listview" /> </LinearLayout>

这里的listview要定义一个id提供后面数据绑定使用,含有内容的显示界面也比较简单,也就是几个textview

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="wrap_content" android:layout_height="wrap_content"> <TextView android:layout_width="60dip" android:layout_height="wrap_content" android:id="@+id/userid" /> <TextView android:layout_width="60dip" android:layout_height="wrap_content" android:id="@+id/username" /> <TextView android:layout_width="90dip" android:layout_height="wrap_content" android:id="@+id/address" /> </LinearLayout>

这样界面的部分就OK了,接下来就是读取数据了,之后显示在listview中,在这里就提供2种方法来显示数据

(1)方法1

package org.lxh.db; import java.util.*; import org.lxh.service.StudentService; import org.lxh.vo.Student; import android.app.Activity; import android.database.Cursor; import android.os.Bundle; import android.view.View; import android.widget.AdapterView; import android.widget.AdapterView.OnItemClickListener; import android.widget.ListView; import android.widget.SimpleAdapter; import android.widget.SimpleCursorAdapter; import android.widget.Toast; public class DBActivity extends Activity { private StudentService service; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); this.service=new StudentService(this); ListView view=(ListView)this.findViewById(R.id.listview); List<Student> all=this.service.fiandAll(); List<HashMap<String,Object>> data=new ArrayList<HashMap<String,Object>>(); //逐个取出元素 Iterator<Student> it=all.iterator(); Student stu=null; while(it.hasNext()){ stu=new Student(); stu=it.next(); HashMap<String,Object> map=new HashMap<String,Object>(); map.put("userid", stu.getUserid()); map.put("username", stu.getUsername()); map.put("address", stu.getAddress()); data.add(map); } //数据绑定 SimpleAdapter adapter=new SimpleAdapter(this, data, R.layout.listview, new String[]{"userid","username","address"},new int[]{R.id.userid,R.id.username,R.id.address}); view.setAdapter(adapter); //添加列表项监听事件 view.setOnItemClickListener(new OnItemClickListener(){ public void onItemClick(AdapterView<?> parent, View view,int position, long id) { ListView listview=(ListView)parent; HashMap<String,Object> hash=(HashMap<String,Object>)listview.getItemAtPosition(position); Toast.makeText(DBActivity.this, hash.get("userid").toString(), 1).show(); }}); }

这里的数据绑定,使用的是SimpleAdapter,我们首先要做的就是把数据逐个取出来存入一个HashMap,如下所示

HashMap<String,Object> map=new HashMap<String,Object>();

这里的hashmap存储的是泛型数据,这个集合的泛型不能随便修改,接下来的工作就是把这个集合当做list的泛型

List<HashMap<String,Object>> data=new ArrayList<HashMap<String,Object>>();

最后要记得把这个map添加到集合里

对于

SimpleAdapter adapter=new SimpleAdapter(this, data, R.layout.listview, new String[]{"userid","username","address"},new int[]{R.id.userid,R.id.username,R.id.address}); view.setAdapter(adapter);

第四个参数里的"userid","username","address"是map集合里的key,最后一个参数是textview,也就是数据界面里的textview.后面还加了个监听,只要点击textview就会显示用户id,android就会通过textview的位置读取内容。

这里把先读数据的代码先贴出来

public List<Student> fiandAll(){ List<Student> all=new ArrayList<Student>(); String sql="select * from student"; SQLiteDatabase database=db.getReadableDatabase(); //使用getReadableDatabase取得SQLiteDatabase Cursor cursor=database.rawQuery(sql, null); //得到游标,类似resultset Student stu; while(cursor.moveToNext()){ //移动游标 int id=cursor.getInt(cursor.getColumnIndex("userid")); String name=cursor.getString(cursor.getColumnIndex("username")); String address=cursor.getString(cursor.getColumnIndex("address")); stu=new Student(); stu.setUserid(id); stu.setUsername(name); stu.setAddress(address); all.add(stu); } cursor.close(); //关闭游标 return all; }

(2)游标适配器

下面是读数据的代码

public Cursor fiandAllCursor(){ List<Student> all=new ArrayList<Student>(); String sql="select userid as _id,username,address from student"; SQLiteDatabase database=db.getReadableDatabase(); //使用getReadableDatabase取得SQLiteDatabase Cursor cursor=database.rawQuery(sql, null); //得到游标,类似resultset //cursor.close(); //这里不可以关闭游标 return cursor; }

这里为主键的列取了别名是因为android内部建议主键设置为_id,但是不可能每个表的主键的名称都是_id

Cursor all=this.service.fiandAllCursor(); //使用游标适配器 SimpleCursorAdapter cadapter=new SimpleCursorAdapter(this, R.layout.listview,all, new String[]{"_id","username","address"},new int[]{R.id.userid,R.id.username,R.id.address}); view.setAdapter(cadapter); //添加列表项监听事件 view.setOnItemClickListener(new OnItemClickListener(){ public void onItemClick(AdapterView<?> parent, View view,int position, long id) { ListView listview=(ListView)parent; Cursor hash=(Cursor)listview.getItemAtPosition(position); //取得被点击item的位置 int temp=hash.getInt(hash.getColumnIndex("_id")); Toast.makeText(DBActivity.this, String.valueOf(temp), 1).show(); }});

这里的适配器参数顺序和上面的有点不同,而且第四个参数里的“usernam”,"address"和'_id'都是表的列名。其他地方没太大区别,上面的“_id”也不能写成别的。否则会出错

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android操作SQLite数据库技巧总结》、《Android数据库操作技巧总结》、《Android编程之activity操作技巧总结》、《Android文件操作技巧汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》、《Android视图View技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

时间: 2024-10-24 22:03:30

Android SQLite事务处理结合Listview列表显示功能示例的相关文章

Android ItemDecoration 实现分组索引列表的示例代码

本文介绍了Android ItemDecoration 实现分组索引列表的示例代码,分享给大家.具体如下: 先来看看效果: 我们要实现的效果主要涉及三个部分: 分组 GroupHeader 分割线 SideBar 前两个部分涉及到一个ItemDecoration类,也是我们接下来的重点,该类是RecyclerView的一个抽象静态内部类,主要作用就是给RecyclerView的ItemView绘制额外的装饰效果,例如给RecyclerView添加分割线. 使用ItemDecoration时需要继

Android入门教程之ListView的应用示例_Android

本文实例讲述了Android ListView的简单应用.分享给大家供大家参考,具体如下: 我们今天要讲的内容是Android中ListView中的实现.一共分为四个步骤,我将一一讲解: Step one:创建一个新的Android工程,命名为ListViewDemo. Step two:找到ListViewDemo.Java,把我们习惯的继承Activity,改成ListActivity,如下: public class ListViewDemo extends ListActivity St

深入Android SQLite 事务处理详解_Android

应用程序初始化时需要批量的向sqlite中插入大量数据,单独的使用for+Insert方法导致应用响应缓慢,因为 sqlite插入数据的时候默认一条语句就是一个事务,有多少条数据就有多少次磁盘操作.我的应用初始5000条记录也就是要5000次读写磁盘操作. 而且不能保证所有数据都能同时插入.(有可能部分插入成功,另外一部分失败,后续还得删除.太麻烦) 解决方法: 添加事务处理,把5000条插入作为一个事务 我们使用SQLite的事务进行控制: 复制代码 代码如下:         db.begi

Android入门教程之ListView的应用示例

本文实例讲述了Android ListView的简单应用.分享给大家供大家参考,具体如下: 我们今天要讲的内容是Android中ListView中的实现.一共分为四个步骤,我将一一讲解: Step one:创建一个新的Android工程,命名为ListViewDemo. Step two:找到ListViewDemo.Java,把我们习惯的继承Activity,改成ListActivity,如下: public class ListViewDemo extends ListActivity St

Android UI组件----ListView列表控件详解

[正文] 内容简介: • 1.基本的XML配置 • 2.ListActivity • 3.单选和多选模式 • 4.ListView实现图文列表 • 5.ListView刷新分页   一.基本的 XML配置: android:cacheColorHint="#00000000"  //设置拖动背景色为透明 android:dividerHeight="30px"  //listview item之间的高度(即分格条的高度) android:divider="

腾讯Android自动化测试实战3.3.2 ListView列表遍历

3.3.2 ListView列表遍历 编写Android端的自动化测试用例,最常见的控件有ListView,而要想测试ListView,就必然要涉及ListView的遍历. 关于ListView的遍历,可能首先想到的是类似如代码清单3-20的实现方式. 代码清单3-20 设想中的列表遍历 for(int i=0;i<listView. getCount();i++){     listView.getChildAt(int index);     --; } 但是,在Android中,对于lis

Android SQLite详解及示例代码_Android

在Android中使用SQLite数据库的入门指南,打算分下面几部分与大家一起分享, 1.什么是SQLite 2.Android中使用SQLite 一.什么是SQLite SQLite是一款开源的.轻量级的.嵌入式的.关系型数据库.它在2000年由D. Richard Hipp发布,可以支援Java.Net.PHP.Ruby.Python.Perl.C等几乎所有的现代编程语言,支持Windows.Linux.Unix.Mac OS.Android.IOS等几乎所有的主流操作系统平台. SQLit

Android开发之ListView列表刷新和加载更多实现方法_Android

本文实例讲述了Android开发之ListView列表刷新和加载更多实现方法.分享给大家供大家参考.具体如下: 上下拉实现刷新和加载更多的ListView,如下: package com.sin.android.ui; import android.content.Context; import android.util.AttributeSet; import android.view.Gravity; import android.view.MotionEvent; import andro

我的Android进阶之旅------&amp;gt;Android二级ListView列表的实现

实现如下图所示的二级列表效果 首先是在布局文件中,布局两个ListView,代码如下: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="fill_parent" android:layout_height=&