Android sqlite 事务级别,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的使用,我们理解成列表就可以了。界面如下

33733d22e7fd0e598b577fe2c29da0b7.png

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

android:orientation="vertical"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

>

xmlns:android="http://schemas.android.com/apk/res/android"

android:orientation="horizontal"

android:layout_width="wrap_content"

android:layout_height="wrap_content">

android:layout_width="60dip"

android:layout_height="wrap_content"

android:text="用户id"

/>

android:layout_width="60dip"

android:layout_height="wrap_content"

android:text="用户名"

/>

android:layout_width="60dip"

android:layout_height="wrap_content"

android:text="用户住址"

/>

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:id="@+id/listview"

/>

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

xmlns:android="http://schemas.android.com/apk/res/android"

android:orientation="horizontal"

android:layout_width="wrap_content"

android:layout_height="wrap_content">

android:layout_width="60dip"

android:layout_height="wrap_content"

android:id="@+id/userid"

/>

android:layout_width="60dip"

android:layout_height="wrap_content"

android:id="@+id/username"

/>

android:layout_width="90dip"

android:layout_height="wrap_content"

android:id="@+id/address"

/>

这样界面的部分就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 all=this.service.fiandAll();

List> data=new ArrayList>();

//逐个取出元素

Iterator it=all.iterator();

Student stu=null;

while(it.hasNext()){

stu=new Student();

stu=it.next();

HashMap map=new HashMap();

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 hash=(HashMap)listview.getItemAtPosition(position);

Toast.makeText(DBActivity.this, hash.get("userid").toString(), 1).show();

}});

}

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

HashMap map=new HashMap();

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

List> data=new ArrayList>();

最后要记得把这个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 fiandAll(){

List all=new ArrayList();

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 all=new ArrayList();

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程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抱歉,我可以回答您的问题。以下是一个示例代码,帮助在 Android Studio 中使用 SQLite 数据库将数据显示ListView 上: 1. 定义 SQLiteOpenHelper 类 public class SqliteHelper extends SQLiteOpenHelper { private static final String DATABASE_NAME = "my_db"; private static final int DATABASE_VERSION = 1; public SqliteHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { String CREATE_TABLE = "CREATE TABLE my_table ( " + "id INTEGER PRIMARY KEY AUTOINCREMENT, " + "name TEXT, " + "age INTEGER )"; db.execSQL(CREATE_TABLE); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String DROP_TABLE = "DROP TABLE IF EXISTS my_table"; db.execSQL(DROP_TABLE); this.onCreate(db); } } 2. 在 Activity 中使用 SQLiteOpenHelper public class MainActivity extends AppCompatActivity { private SqliteHelper dbHelper; private ListView listView; private ArrayAdapter<String> adapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); dbHelper = new SqliteHelper(this); listView = (ListView)findViewById(R.id.listView); adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, android.R.id.text1); listView.setAdapter(adapter); SQLiteDatabase db = dbHelper.getWritableDatabase(); Cursor cursor = db.rawQuery("SELECT * from my_table", null); if (cursor.moveToFirst()) { do { String name = cursor.getString(cursor.getColumnIndex("name")); int age = cursor.getInt(cursor.getColumnIndex("age")); adapter.add("Name: " + name + ", Age: " + age); } while (cursor.moveToNext()); } cursor.close(); db.close(); } } 在这个示例代码中,我们首先定义了 SqliteHelper 类,这是一个 SQLiteOpenHelper 的子类。我们在 onCreate() 中创建了一个名为 my_table 的表格,并在 onUpgrade() 中定义了如何升级我们的数据库。 然后,在 MainActivity 中,我们使用 SqliteHelper 类创建了一个 SQLiteDatabase 对象,并使用 Cursor 对象从 my_table 表格中获取数据。最后,我们使用 ArrayAdapter 将数据添加到 ListView 中。 希望这个示例代码可以帮助您实现在 Android Studio 中使用 SQLite 数据库将数据显示ListView 上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值