簡體   English   中英

從Android中的Spinner選定項中檢索編輯文本中的SQLite數據

[英]Retrieve SQLite data in edit text from Spinner selected item in Android

我在Activity和edittext中有旋轉器。 當我運行該應用程序時,我會收到nullPointerException的警告。我沒有在onCreate()中的編輯文本中檢索SQLite數據。有人可以幫幫我。 這是我的代碼。

public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.delete_entry);

        databaseHelper = new DatabaseHelper(this);
        databaseHelper.onOpen(db);

        spinner_searchByEmpName = (Spinner)findViewById(R.id.searchByEmpName);
        loadSerachBYProject() ;

        spinner_searchByEmpName.setOnItemSelectedListener(new OnItemSelectedListener() {

            @Override
            public void onItemSelected(AdapterView<?> arg0, View arg1,
                    int arg2, long arg3) {
                // TODO Auto-generated method stub
                selectedEmployeeName = spinner_searchByEmpName.getSelectedItem().toString().trim();
                System.out.println("selectedProjectName " + selectedEmployeeName);

            }

            @Override
            public void onNothingSelected(AdapterView<?> arg0) {
                // TODO Auto-generated method stub

            }
        });


          etEmpName=(EditText)findViewById(R.id.Delete_editText_StaffEmployee_Name);
          etDepartment=(EditText)findViewById(R.id.Delete_editText_Department);
          etDesignation=(EditText)findViewById(R.id.Delete_editText_Designation);

        try {

            Cursor cursor = db.rawQuery("SELECT staff_employee_id, staff_emp_name, department, designation FROM employee_details WHERE staff_emp_name = ?",
                            new String[] { "" + selectedEmployeeName });

            etEmpName.setText(cursor.getString(cursor
                    .getColumnIndex("staff_emp_name")));

            etDepartment.setText(cursor.getString(cursor
                    .getColumnIndex("department")));

            etDesignation.setText(cursor.getString(cursor
                    .getColumnIndex("designation")));
        }

        catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }


    }


    private void loadSerachBYProject() 
    {
        DatabaseHelper databaseHelper = new DatabaseHelper(getApplicationContext());
        // Spinner Drop down elements
                List<String> projectsName = databaseHelper.getAllEmployeeName();

                // Creating adapter for spinner
                ArrayAdapter<String> dataAdapter = new ArrayAdapter<String>(this,android.R.layout.simple_spinner_item, projectsName);

                // Drop down layout style - list view with radio button
                dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

                // attaching data adapter to spinner
                spinner_searchByEmpName.setAdapter(dataAdapter);
    }


}

提前致謝。

這是我的日志貓錯誤信息

06-26 18:08:09.073: W/System.err(601): java.lang.NullPointerException
06-26 18:08:09.083: W/System.err(601):  at com.employee_review.Update_Entry.onCreate(Update_Entry.java:68)
06-26 18:08:09.083: W/System.err(601):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
06-26 18:08:09.083: W/System.err(601):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
06-26 18:08:09.083: W/System.err(601):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
06-26 18:08:09.092: W/System.err(601):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
06-26 18:08:09.092: W/System.err(601):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
06-26 18:08:09.103: W/System.err(601):  at android.os.Handler.dispatchMessage(Handler.java:99)
06-26 18:08:09.103: W/System.err(601):  at android.os.Looper.loop(Looper.java:123)
06-26 18:08:09.113: W/System.err(601):  at android.app.ActivityThread.main(ActivityThread.java:3683)
06-26 18:08:09.123: W/System.err(601):  at java.lang.reflect.Method.invokeNative(Native Method)
06-26 18:08:09.133: W/System.err(601):  at java.lang.reflect.Method.invoke(Method.java:507)
06-26 18:08:09.133: W/System.err(601):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
06-26 18:08:09.133: W/System.err(601):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
06-26 18:08:09.133: W/System.err(601):  at dalvik.system.NativeStart.main(Native Method)

我猜試試看

if(cursor!=null){
  etEmpName.setText(cursor.getString(cursor
            .getColumnIndex("staff_emp_name")));

    etDepartment.setText(cursor.getString(cursor
            .getColumnIndex("department")));

    etDesignation.setText(cursor.getString(cursor
            .getColumnIndex("designation")));  
}  

db從未初始化。 它必須在onCreate()中初始化,因為這是在Activity中運行的第一個方法。 我看到這個:

databaseHelper = new DatabaseHelper(this);
databaseHelper.onOpen(db);

我猜你真的應該有這個:

databaseHelper = new DatabaseHelper(this);
db=databaseHelper.getReadableDatabase();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM