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

android数据库未关闭异常,我在SQLite(Android)中收到数据库对象未关闭异常,但我明确地关闭了我的数据库...帮助?...

02-0816:35:00.899:ERROR数据库(468):android.database.sqlite.Databa

02-08 16:35:00.899:ERROR /数据库(468):android.database.sqlite.DatabaseObjectNotClosedException:应用程序没有关闭这是这里打开光标或数据库对象

除了,我是。这里是方法,其中这个问题正在发生:

public static void getUpdates(String username, Context context) {

HttpClient httpClient = new DefaultHttpClient();

HttpPost httpPost = new HttpPost("http://10.0.2.2/tag/appgetfriendinfo.php");

try {

List nVPs = new ArrayList();

nVPs.add(new BasicNameValuePair("username", username));

httpPost.setEntity(new UrlEncodedFormEntity(nVPs));

HttpResponse response = httpClient.execute(httpPost);

ResponseHandler rHandler = new BasicResponseHandler();

String result = rHandler.handleResponse(response);

JSONArray jArray = new JSONArray(result);

for(int i = 0; i

JSONObject jObj = jArray.getJSONObject(i);

String userCheck = jObj.getString("username");

TagDBAdapter dbHelper = new TagDBAdapter(context);

dbHelper.open();//OPENING THE DATABASE

Contact contact = new Contact();

String first = jObj.getString("firstname");

String last = jObj.getString("lastname");

String name = first + " " + last;

contact.setUsername(jObj.getString("username"));

contact.setFirstName(first);

contact.setLastName(last);

contact.setName(name);

contact.setPhoneNumber(jObj.getString("phonenumber"));

contact.setEmail(jObj.getString("email"));

contact.setHomePhone(jObj.getString("homephone"));

contact.setWorkPhone(jObj.getString("workphone"));

if(dbHelper.checkForExisting(userCheck) == true) {

dbHelper.createContact(contact);

}

else {

dbHelper.updateContactAuto(userCheck, contact);

}

dbHelper.close();//CLOSING THE DATABASE

}

} catch(ClientProtocolException e) {

Log.e("GETUPDATES", "CPE", e);

e.printStackTrace();

} catch(IOException e) {

Log.e("GETUPDATES", "IOE", e);

e.printStackTrace();

} catch(JSONException e) {

Log.e("GETUPDATES", "JSONE", e);

e.printStackTrace();

}

}

正如你可以在我的//注释,我打开和关闭数据库,但我仍然得到错误指出行看到。这里有些奇怪,但是错误的来源在SQLite的open()方法中。

ERROR /数据库(468):在com.tagapp.android.TagDBAdapter.open(TagDBAdapter.java:62)

这是这样的:

/**THESE ARE MY DBADAPTER'S OPEN AND CLOSE METHODS*/

public TagDBAdapter open() throws SQLException {

mDBHelper = new DatabaseHelper(m_context);

mDb = mDBHelper.getWritableDatabase();

return this;

}

public void close() {

mDBHelper.close();

}

这些都是直接从谷歌的记事本教程,他们在不同的情况下为我工作了100%。有没有人知道这里发生了什么?非常感谢。

+0

@psyhclo我会需要看到你的活动在那里帮助你,如果你可以发布它,我会尽力帮助 –

2011-02-09 06:06:24

+0

好吧,我已将活动添加到帖子末尾。你可以检查相同的链接。 http://www.stackoverflow.com/questions/4921550/where-to-close-the-database谢谢。 –

2011-02-09 14:03:13



推荐阅读
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 本文介绍了将mysql从5.6.15升级到5.7.15的详细步骤,包括关闭访问、备份旧库、备份权限、配置文件备份、关闭旧数据库、安装二进制、替换配置文件以及启动新数据库等操作。 ... [详细]
author-avatar
手机用户2502857731
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有