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 无法将数据库加载到片段内的列表视图中 的相关文章

  • ExtJS GridPanel 中的垂直滚动条

    我正在开发一个项目 其中页面上有一个 GridPanel 该面板可以显示任意数量的行 并且我设置了 autoHeight 属性 这会导致 GridPanel 扩展以适合行数 我现在想要一个水平滚动条 因为在某些分辨率下 并非所有列都会显示
  • 使用和不使用 SciPy 计算 k 组合的数量

    我对这个函数感到困惑combSciPy 的 http docs scipy org doc scipy 0 14 0 reference generated scipy misc comb html看起来比简单的 Python 实现要慢 这
  • Google 地图 v3 信息窗口在地图视口外打开

    如果单击地图视口顶部附近的标记 信息窗口将加载到可视区域之外 并且必须拖动地图才能查看信息窗口内容 理想情况下 我不希望地图自动平移 有没有办法以不同的方向加载信息窗口 例如如果标记位于视口的顶部 则以向下的方向显示信息窗口 不 你不能以不
  • Cassandra 中的数据分布

    我听说过 Cassandra 及其发行版 其实想知道数据在整个集群中是如何分布的现象 我的意思是 Cassandra 如何决定哪些节点拥有哪些数据 如果您了解 HashTable 数据结构以及 Hashtable 中如何进行哈希处理 那么这
  • travis-ci 安装程序使用 --github-token 发布

    我在使用带有 github 令牌的安装版本时遇到问题 我喜欢 travis ci 但我不愿意透露我的 github 密码 我需要使用令牌并且我阅读了文档 因为这应该可以通过这种方式实现 不幸的是它仍然要求输入密码 travis login
  • bin 文件夹内任何文件的任何更改是否会导致 ASP.NET Web 应用程序中的应用程序回收?

    我知道在 ASP NET Web 应用程序中 更改位于bin文件夹会导致应用程序回收 但我想知道 正如主题所暗示的那样 是否any文件更改会导致这种行为吗 此场景中是否包含简单的文本文件 那么子文件夹呢 bin文件夹 它们的内容呢 我知道我
  • 并行 Haskell - GHC GC 火花

    我有一个正在尝试并行化的程序 带有可运行代码的完整粘贴here http lpaste net 101528 我进行了分析 发现大部分时间都花在findNearest这本质上是一个简单的foldr超过一个大Data Map findNear
  • 是否可以将 Vagrant 与 intelliJ 一起使用?

    假设我正在使用 Java 并使用 IntelliJ 来执行构建和部署等操作以及其他类似操作 我以前没有使用过 Vagrant 但是在运行 Vagrant 实例时是否可以继续使用 IntelliJ 进行构建和部署 是的 您可以将 IDE 与
  • 每次都在django查询数据库中过滤查询集吗?

    想象一下我有以下代码 qs Users objects all list for i in range 10 list append qs filter age i 这里过滤器被调用 10 次 它是连接到数据库 10 次还是第一次使用过滤器
  • 如何对数字进行排序? [复制]

    这个问题在这里已经有答案了 下面是代码 Is the sortNumber对数字进行排序的函数 a 和 b 是什么意思以及为什么存在 为什么sortNumber in n sort sortNumber 没有指定任何参数a and b Ja
  • 如何设置打开文件时默认展开?

    In my vimrc我已经把set foldmethod syntax启用方法折叠等 但是 我不喜欢每次打开文件时都会折叠整个文件的默认设置 有没有办法启用foldmethod 但是当我打开文件时文件是否展开了 set foldlevel
  • 从 Bigcommerce 的浏览器内存中删除注入的分析库?

    我们如何删除这个脚本注入器系统并清除内存中的函数 简报 最近 Bigcommerce 的不法分子以 监控 为幌子创建了一个分析注入器 JS 该注入器被锁定在全局变量中 他们在未经任何 OP 同意的情况下将其推广到所有 50 000 家前台商
  • 是什么让热部署成为“难题”?

    在工作中 我们经常遇到这样的问题 永久代内存不足 http www jroller com agileanswers entry preventing java s java lang例外 团队负责人认为这是 JVM 中的一个错误 与代码的
  • 当页面加载图像时,它是只加载一次,还是每次在标记中找到它时加载?

    当页面加载图像时 它是只加载一次 还是每次在标记中找到它时加载 那么 jquery 呢 附加一个 img 会导致它再次重新加载吗 我问这个问题是因为我有高分辨率图像 但需要在标记的许多情况下使用它 img src hello jpg img
  • qt 如何知道按钮被点击?

    我正在尝试编写一个程序 用声音进行一些操作 我的问题是我有 3 个播放按钮和 3 个标签 我希望无论我单击 播放 按钮 都应该播放按钮附近标签中名称的声音 我有一个没有任何参数的播放插槽 那么 如何分别连接到每个播放按钮和每个标签呢 实际上
  • JavaScript Uncaught ReferenceError:jQuery 未定义;未捕获的引用错误:$未定义[重复]

    这个问题在这里已经有答案了 这是我的小提琴http jsfiddle net 4vaxE 35 http jsfiddle net 4vaxE 35 它在我的小提琴中工作得很好 但是 当我将其转移到dreamweaver时 它无法工作 我在
  • 在 Rx 中,如何按 id 对事件进行分组并按多个时间跨度限制每个组?

    可以这么说 我陷入了 Rx 热潮 这个问题与我的相关here https stackoverflow com questions 19425965 rx how to group by a key a complex object and
  • Django 无法覆盖表单字段小部件

    我需要在表单中生成基于列的复选框 myapp templates forms widgets custom html div class row for group options index in widget optgroups for
  • 使用 Fetch 发生超时错误 - React Native

    我有一个正在运行的用户登录功能 但是 我想在获取时加入超时错误 有没有办法设置一个 5 秒左右的计时器 这样在这个时间之后就会停止尝试获取 否则 一段时间后我就会出现红屏 提示网络错误 userLogin var value this re
  • 当支持 SPDY 的浏览器收到 HTTP2 (H2) 响应时会发生什么?

    我的直觉是 支持 SPDY 的浏览器会将其视为 SPDY 响应 然而 我能找到的最多的是 H2 响应将优雅地降级到 HTTP1 1 的保证 我正在考虑以面向 H2 的方式提供资产 多个请求 无域分片等 但我确实需要支持一些非 H2 浏览器

随机推荐