Android:NullPointerException 无法将数据库加载到片段内的列表视图中

2024-04-03

我已经搜索了一段时间,试图找到如何使用 MySQLite 数据库中的信息填充列表视图。现在,当我认为我终于找到了一些信息时,我想到了空指针。

这是我的代码(HomeFragment.java):

package zygs.com.seniorproject.fragments;

import android.app.Fragment;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.View.OnClickListener;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;

import java.util.ArrayList;
import java.util.List;

import zygs.com.seniorproject.R;
import zygs.com.seniorproject.database.DatabaseHandler;
import zygs.com.seniorproject.database.Inventory;

public class HomeFragment extends Fragment {

// Initializing Variables
Button Item_Button;
Button Display_Button;
EditText Box_Item_Des;
EditText Box_Item_Quant;
EditText Box_Item_ID;
final DatabaseHandler db = new DatabaseHandler(getActivity());


public HomeFragment(){}

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {

    setHasOptionsMenu(true);

    final View rootView = inflater.inflate(R.layout.fragment_home, container, false);
    ListView listContent = (ListView)rootView.findViewById(R.id.inventory_list);

    Item_Button = (Button)rootView.findViewById(R.id.add_item);
    Display_Button = (Button)rootView.findViewById(R.id.display_button);
    Box_Item_Des = (EditText)rootView.findViewById(R.id.Item_Des);
    Box_Item_ID = (EditText)rootView.findViewById(R.id.Item_ID);
    Box_Item_Quant = (EditText)rootView.findViewById(R.id.Item_Quant);

    Item_Button.setOnClickListener(
            new View.OnClickListener() {
                public void onClick(View view) {

                    // Grab Information from Text Boxes
                    String Item_Des = Box_Item_Des.getText().toString();
                    int Item_Quantity = Integer.parseInt(Box_Item_Quant.getText().toString());
                    int Item_ID = Integer.parseInt(Box_Item_ID.getText().toString());

                    db.addItem(new Inventory(Item_ID, Item_Des, Item_Quantity));
                }
            }
    );

    Display_Button.setOnClickListener(
            new OnClickListener() {
                public void onClick(View view){

                    Log.d("Reading: ", "Reading all Inventory");
                    List<Inventory> inventoryList = db.getAllItems();

                    for (Inventory in : inventoryList) {
                        String log = "Id: " + in.getItemID() + ", Name: " + in.getItemName() + " , Quantity: " + in.getItemQuant();

                        //Write List to Log
                        Log.d("Name:", log);
                    }

                }
            }
    );

    List<Inventory> inv_list = getAllInventory();
    ArrayAdapter adapter = new ArrayAdapter(getActivity(), android.R.layout.simple_list_item_1, inv_list);
    listContent.setAdapter(adapter);



    return rootView;
}

public List<Inventory> getAllInventory() {

    List<Inventory> contactList = new ArrayList<Inventory>();

    String selectQuery = "SELECT * FROM Inventory";
    SQLiteDatabase data = db.getWritableDatabase();

    Cursor cursor = data.rawQuery(selectQuery, null);

    if (cursor.moveToFirst()) {
        do {
            Inventory inventory = new Inventory();
            inventory.setItemID(Integer.parseInt(cursor.getString(0)));
            inventory.setItemName(cursor.getString(1));
            inventory.setItemQuant(Integer.parseInt(cursor.getString(2)));
        } while (cursor.moveToNext());
    }
    return contactList;
}

}

我正在使用来自的数据库处理程序Android蜂巢 http://www.androidhive.info/2011/11/android-sqlite-database-tutorial/

这是代码:

package zygs.com.seniorproject.database;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

import java.util.ArrayList;
import java.util.List;

public class DatabaseHandler extends SQLiteOpenHelper {

//Logcat Tag
private static final String LOG = "DatabaseHelper";

//Database Version
private static final int DATABASE_VERSION = 2;

//Database Name
private static final String DATABASE_NAME = "InventoryManager";

//Tables
private static final String TABLE_INVENTORY = "Inventory";
private static final String TABLE_KITS = "Kits";

// Common Keys
private static final String KEY_ITEM_ID = "item_id";

//Kits Table Columns Name
private static final String KEY_ID = "_id";
private static final String KEY_KIT_ID = "kit_id";
private static final String KEY_KIT_NAME = "kit_name";

//Inventory Tables Columns Names
private static final String KEY_ITEM_NAME = "item_name";
private static final String KEY_ITEM_QUANT = "item_quant";

public DatabaseHandler(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

//Creating Tables Strings
private static final String CREATE_INVENTORY_TABLE = "CREATE TABLE " + TABLE_INVENTORY + "(" + KEY_ITEM_ID + " INTEGER PRIMARY KEY," + KEY_ITEM_NAME + " TEXT," + KEY_ITEM_QUANT + " INTEGER" + ");";
private static final String CREATE_KIT_TABLE = "CREATE TABLE " + TABLE_KITS + "(" + KEY_ID + " AUTOINCREMENT INTEGER PRIMARY KEY," + KEY_KIT_ID + " INTEGER," + KEY_KIT_NAME + " TEXT," + KEY_ITEM_ID + " INTEGER" + ");";


//Create Tables
@Override
public void onCreate(SQLiteDatabase db) {

    db.execSQL(CREATE_INVENTORY_TABLE);
    db.execSQL(CREATE_KIT_TABLE);
}

//Upgrading Database
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    //Drop older table if existed
    db.execSQL("DROP TABLE IF EXISTS " + TABLE_INVENTORY);

    // Create Tables again;
    onCreate(db);
}


/////////////////////////////////////////
/////// CREATE READ UPDATE DELETE //////
///////////////////////////////////////

//Add a new record
public void addItem(Inventory inventory) {
    SQLiteDatabase db = this.getWritableDatabase();

    ContentValues values = new ContentValues();
    values.put(KEY_ITEM_NAME, inventory.getItemName());     // Item Name
    values.put(KEY_ITEM_ID, inventory.getItemID());         // Item ID
    values.put(KEY_ITEM_QUANT, inventory.getItemQuant());   //Item Quantity

    //Insert Row
    db.insert(TABLE_INVENTORY, null, values);
    db.close();

}

// Query a single Item
//public Inventory getItemID(int id) {}

//Query All Items
public List<Inventory> getAllItems() {
    List<Inventory> inventoryList = new ArrayList<Inventory>();

    // Select All Query
    String selectQuery = "SELECT * FROM " + TABLE_INVENTORY;

    SQLiteDatabase db = this.getWritableDatabase();
    Cursor cursor = db.rawQuery(selectQuery, null);

    //Looping through all rows and adding to list
    if (cursor.moveToFirst()) {
        do {
            Inventory inventory = new Inventory();
            inventory.setItemID(Integer.parseInt(cursor.getString(0)));
            inventory.setItemName(cursor.getString(1));
            inventory.setItemQuant(Integer.parseInt(cursor.getString(2)));

            //Adding Inventory to List
            inventoryList.add(inventory);
        } while (cursor.moveToNext());
    }

    //Return Inventory List
    return inventoryList;

}



// Query Item Count
//public int getItemCount() {}

//Update Single Item
//public int updateItem(Inventory inventory) {}

//Delete Single Item
//public void deleteItem(Inventory inventory){}


}

我得到的错误日志如下:

04-09 13:34:54.187    6393-6393/zygs.com.seniorproject E/AndroidRuntime﹕ FATAL EXCEPTION: main
    Process: zygs.com.seniorproject, PID: 6393
    java.lang.RuntimeException: Unable to start activity ComponentInfo{zygs.com.seniorproject/zygs.com.seniorproject.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'android.database.sqlite.SQLiteDatabase android.content.Context.openOrCreateDatabase(java.lang.String, int, android.database.sqlite.SQLiteDatabase$CursorFactory, android.database.DatabaseErrorHandler)' on a null object reference
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2693)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2758)
            at android.app.ActivityThread.access$900(ActivityThread.java:177)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1448)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:145)
            at android.app.ActivityThread.main(ActivityThread.java:5942)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194)
     Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.database.sqlite.SQLiteDatabase android.content.Context.openOrCreateDatabase(java.lang.String, int, android.database.sqlite.SQLiteDatabase$CursorFactory, android.database.DatabaseErrorHandler)' on a null object reference
            at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:223)
            at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:163)
            at zygs.com.seniorproject.fragments.HomeFragment.getAllInventory(HomeFragment.java:97)
            at zygs.com.seniorproject.fragments.HomeFragment.onCreateView(HomeFragment.java:83)
            at android.app.Fragment.performCreateView(Fragment.java:2114)
            at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:904)
            at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1082)
            at android.app.BackStackRecord.run(BackStackRecord.java:833)
            at android.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467)
            at android.app.Activity.performStart(Activity.java:6328)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2656)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2758)
            at android.app.ActivityThread.access$900(ActivityThread.java:177)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1448)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:145)
            at android.app.ActivityThread.main(ActivityThread.java:5942)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)

感谢您为我提供的任何帮助。


线路final DatabaseHandler db = new DatabaseHandler(getActivity());在类的顶部声明,因此创建 Fragment getActivity() 将返回空引用。

如果将其移至 onCreate() 方法内,您将获得数据库处理程序可以使用的 Activity 引用。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Android:NullPointerException 无法将数据库加载到片段内的列表视图中 的相关文章

  • 如何在 eclipse 中安装最新版本的 Xuggler(5.4,截至 18/05/2013)?

    我真的不知道从哪里开始这样做 我已经从网站下载了必要的 Jar 并对如何在 Eclipse 中安装 Xuggler 进行了一些研究 但所有内容都已过时或不相关 我的系统是 64 位 Windows 8 大多数在 Vista 和 Window
  • 使用属性初始化 Angular 2 组件[重复]

    这个问题在这里已经有答案了 有没有办法将参数传递到 Angular 2 组件的根 我已经能够使用属于内部组件模板一部分的组件来执行此操作 但不能使用根组件来执行此操作
  • 比较(密码)属性

    我想使用下面的代码为新用户创建一个视图模型 User 类仅包含我将保留到数据库的两个属性 目前已简化 视图模型添加了一个 比较密码 字段 该字段仅在视图中使用 我更喜欢让视图模型直接使用 User 类 而不是重复 User 中定义的所有字段
  • 您使用哪种 IDE(如果有)构建 python GUI 项目?

    是否有任何 IDE 如 VS 支持拖放来构建 python GUI 连接到数据库等 尽管我是一个 emacs 爱好者 但我发现使用 VS 创建 GUI 更容易 仅对于 GUI 我发现 VisualWx http visualwx alter
  • 启动应用程序时反应本机 Android 错误

    V SoLoader libimagepipeline so not found on data data com learnapp lib main D SoLoader libimagepipeline so found on data
  • 图像选择器在 React Native 应用程序中不起作用,为什么?

    我已经成功安装了react native image picker 对于一个新的react本机应用程序 链接它并通过info plist文件授予正确的权限来访问相机 照片等 我正在使用 React native image picker 页
  • 在实际应用或执行之前验证 yaml 中定义的 OpenShift 对象

    我在 template yaml 文件中有一个 OpenShift 模板 其中包括以下对象 部署配置 pod 服务和路由 我使用以下命令来执行 yaml oc process f template yml oc apply f 我想在实际应
  • 将 WebView 保存为 PDF 返回空白图像?

    我正在尝试弄清楚如何将 WebView 保存到 PDF 并且完全卡住了 真的很感激一些帮助吗 我在 OSX 上的 Cocoa 和 Swift 中执行此操作 这是到目前为止我的代码 import Cocoa import WebKit cla
  • 如何根据对象属性字符串过滤“ngFor”循环内的项目

    我需要过滤里面的项目ngFor循环 通过更改下拉列表中的类别 因此 当从列表中选择特定类别时 它应该只列出包含该相同类别的项目 HTML 模板
  • java中的长轮询

    我已经编写了用于长轮询的服务器端代码 我想用java写客户端程序 因此 根据长轮询 客户端发送一个由服务器帮助的请求 当事件发生时服务器响应该请求 然后客户端发送新的请求 所以我面临的麻烦是用java编写的客户端 发送请求后 如何继续检查客
  • 通过 powershell 将调试器附加到多个进程

    我有几个正在运行的进程 我想通过 powershell 将它们附加到 VS 调试器 目前 我可以这样做 Get Process NServiceBus Host Debug Process 如果只有一个进程 系统会提示我选择正确的调试器 然
  • 谷歌模拟 - 我可以在同一个模拟对象上多次调用 EXPECT_CALL 吗?

    如果我打电话EXPECT CALL在同一个模拟对象上两次TEST F 会发生什么 期望是否附加到模拟对象中 或者第二次调用是否消除了第一次调用的效果 I found 后子句 https github com google googletes
  • 如何等待进程及其所有子进程退出?

    是否有一个等待方法 当目标进程及其所有子进程退出时会返回 看来 Process WaitForExit 只会等待目标进程 net 中有一个错误会给出您所追求的行为 WaitForExit 如果您异步读取输出 将等待所有子进程 p Start
  • python easy_install:指定存放所需文件的目录

    我正在尝试使用 easy install 来安装 MySQL python 它几乎立即失败 mysql c 36 23 错误 my config h 没有这样的文件或目录 mysql c 38 19 错误 mysql h 没有这样的文件或目
  • Windows 窗体应用程序中异常处理的最佳实践?

    我目前正在编写我的第一个 Windows 窗体应用程序 我现在已经阅读了几本 C 书籍 因此对 C 必须处理异常的语言特性有了相对较好的了解 然而 它们都非常理论化 因此我还没有了解如何将基本概念转化为应用程序中良好的异常处理模型 有人愿意
  • 使用部署在 Tomcat 中的 Web 应用程序关闭 Tomcat

    我对我的 webapp 开发中遇到的 tomcat 操作有一些疑问 有什么办法可以从部署在tomcat中的web应用程序中关闭tomcat本身吗 tomcat 是否在一个 JVM 或单个 JVM 中运行其所有 webapps war 或者在
  • GHC 截断 Unicode 字符输出

    我无法让 GHCi 或 GHC 打印 unicode 代码点 221A 平方符号 我不认为这是我的外壳 因为我可以让 ruby 来做 irb gt puts u221A GHC GHCi 是另一个问题 ghci gt putStrLn 87
  • 使用深度名称向量作为索引替换嵌套列表

    采取一个简单的嵌套列表L L lt list lev1 list lev2 c bit1 bit2 other list yep 1 L lev1 lev1 lev2 1 bit1 bit2 other other yep 1 1 一个向量
  • 在模拟器中实施应用内结算

    我一直在阅读有关 Android 应用程序的 实施应用内计费 的内容 并且文档说不可能在模拟器中测试该应用程序 真的吗 我正在开发的手机没有 移动数据计划 因此我尝试通过 USB 通过 PC 连接手机 但由于我的 PC 位于代理后面 因此我
  • 获取非通用任务的结果

    有没有办法得到结果Task

随机推荐