文档章节

Finalizing a Cursor that has not been deactivated or closed

w
 walala_Lee
发布于 2014/04/26 10:10
字数 247
阅读 49
收藏 0

Finalizing a Cursor that has not been deactivated or closed

 


先贴出代码:

 

 

public List<UnitInfo> findAllGroup() {
		List<UnitInfo> infos=new ArrayList<UnitInfo>();
		try {
			db = dbManager.openDatabase();
			String sql="SELECT * FROM dict_unit_display";
			System.out.println("-------db---open------:"+db.isOpen());
			cursor=db.query("dict_unit_display", null, null, null, null, null, null);
			System.out.println("---------------cursor--close---:"+cursor.isClosed());
			while (cursor.moveToNext()) {
				UnitInfo unit=new UnitInfo();
				unit.setId(cursor.getLong(cursor.getColumnIndex("ID")));
				unit.setUnitCode(cursor.getString(cursor.getColumnIndex("UNIT_CODE")));
				unit.setUnitName(cursor.getString(cursor.getColumnIndex("UNIT_NAME")));
				unit.setUnitSimpleName(cursor.getString(cursor.getColumnIndex("UNIT_SIMPLE_NAME")));
				unit.setUnitNode(cursor.getString(cursor.getColumnIndex("UNIT_NODE")));
				unit.setUnitFatherNode(cursor.getString(cursor.getColumnIndex("UNIT_NODE_FATHER")));
				System.out.println("----------------------------------");
				System.out.println("-----ID-----:"+ unit.getId());
				System.out.println("-----UNIT_CODE-----:" + unit.getUnitCode());
				System.out.println("-----UNIT_NAME-----:" + unit.getUnitName());
				System.out.println("-----UNIT_SIMPLE_NAME-----:" + unit.getUnitSimpleName());
				System.out.println("-----UNIT_NODE-----:" + unit.getUnitNode());
				System.out.println("-----UNIT_NODE_FATHER-----:" + unit.getUnitFatherNode());
				System.out.println("----------------------------------");
				infos.add(unit);
			}
		} catch (Exception e) {
			System.out.println("------findAllGroup-----数据读取错误");
		} finally {
			DBManager.closeDatabase(db, cursor);
		}
		return infos;
	}
 

代码写的看似没有任何问题,但是由于Cursor的独特性,不得不吐糟下,Cursor取值采用的是先取下标再根据下标去取对应的返回值,这里面就有个问题,如果当前字段在数据库中为 空值 那么通过Cursor  getString()或者getLong()的时候就会出现问题,进而导致一连串的错误。


解决方法就是直接用下标去取值就行了。

 

© 著作权归作者所有

共有 人打赏支持
上一篇: EL表达式取值
w
粉丝 3
博文 167
码字总数 50381
作品 0
深圳
私信 提问
关于Finalizing a Cursor that has not been deactivated or closed.

项目运行中,抛出这样的异常Finalizing a Cursor that has not been deactivated or closed. 07-14 15:53:24.698: ERROR/Cursor(10891): android.database.sqlite.DatabaseObjectNotClosedEx......

黑菜妞妞
2011/07/14
12K
14
Android 访问数据库报错,什么原因

11-21 06:32:38.150: E/Database(1254): close() was never explicitly called on database '/data/data/com.bankb2c.activity/databases/BankService.db' 11-21 06:32:38.150: E/Database(1......

蓝色鸣鸟
2012/11/21
2K
3
Monitoring Open and Cached Cursors

Just about every DBA has had to deal with ora-1000 errors, "Maximum open cursors exceeded." This article will discuss initialization parameters that affect open cursors, the dif......

东皇巴顿
2017/09/07
0
0
Attempted to access a cursor after it has been clo

http://blog.csdn.net/ID19870510/article/details/7682030 [html] view plaincopy android.database.StaleDataException: Attempted to access a cursor after it has been closed. at andr......

塔塔米
2014/02/15
0
0
关于PhantomReference研究的一个问题

package com.sunhang; //: containers/References.java// Demonstrates Reference objectsimport java.lang.ref.;import java.util.; class VeryBig { private static final int SIZE = 1000......

蚂蚁的世界
2015/07/11
0
0

没有更多内容

加载失败,请刷新页面

加载更多

(荷兰)彼得·冯·门施著:博物馆学研究的目的

博物馆学研究的目的 (荷)彼得·冯·门施 尽管诸多关于博物馆学认知目的的不同看法可以被归纳为数个主要群体,但没有一个群体可以被称为“学派”。一般来说,学派是由于博物馆学研究目的的不...

乔老哥
10分钟前
0
0
Vue slot的用法

之前看官方文档,由于自己理解的偏差,不知道slot是干嘛的,看到小标题,使用Slot分发内容,就以为 是要往下派发内容。然后就没有理解插槽的概念。其实说白了,使用slot就是先圈一块地,将来...

peakedness丶
22分钟前
1
0
解析如何用爬虫程序批量采集梨视频数据

本文介绍如何使用爬虫程序免费采集梨视频拍客的视频标题、链接、简介等信息。 采集字段: 视频标题 视频链接 点赞数 视频时长 发布时间 拍客 拍客链接 视频简介 标签 功能点目录: 如何对采集...

技术阿飞
28分钟前
2
0
《阿里铁军》的读书笔记和读后感范文2600字

《阿里铁军》的读书笔记和读后感范文2600字: 在中国互联网,有一个流传很广的说法是,百度强在技术,腾讯强在产品,阿里强在运营。虽然发展到今天,已经不能再用这样简单的视角来看待这三个...

原创小博客
57分钟前
5
0
怎样实际项目中运用责任链模式

1 模式概要 1.1 简介 责任链模式为请求创建一个接收者对象链,每个接收者都包含对另一个接收者的引用,如果一个对象不能处理该请求,那么它会把请求传给下一个接收者,依此类推 责任链模式避...

小刀爱编程
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部