簡體   English   中英

從另一個類調用數據庫對象時,無法插入記錄

[英]unable insert record when database object is called from another class

首先,我是android和Java的新手。

我發展,我寫了單獨的類一個Android應用程序databasetablesdatabase ,現在我想通過創建對象數據庫類和表類,以使插入來自不同總類的表。

我收到以下日志文​​件中的錯誤,不明白它們的確切含義。

01-27 15:15:42.283: D/libEGL(17506): loaded /system/lib/egl/libEGL_genymotion.so
01-27 15:15:42.287: D/(17506): HostConnection::get() New Host Connection established 0xb891b390, tid 17506
01-27 15:15:42.363: D/libEGL(17506): loaded /system/lib/egl/libGLESv1_CM_genymotion.so
01-27 15:15:42.367: D/libEGL(17506): loaded /system/lib/egl/libGLESv2_genymotion.so
01-27 15:15:42.743: W/EGL_genymotion(17506): eglSurfaceAttrib not implemented
01-27 15:15:42.767: E/OpenGLRenderer(17506): Getting MAX_TEXTURE_SIZE from GradienCache
01-27 15:15:42.823: E/OpenGLRenderer(17506): Getting MAX_TEXTURE_SIZE from Caches::initConstraints()
01-27 15:15:42.827: D/OpenGLRenderer(17506): Enabling debug mode 0
01-27 15:15:45.567: I/Choreographer(17506): Skipped 39 frames!  The application may be doing too much work on its main thread.
01-27 15:15:45.831: D/AndroidRuntime(17506): Shutting down VM
01-27 15:15:45.855: W/dalvikvm(17506): threadid=1: thread exiting with uncaught exception (group=0xa4b8c648)
01-27 15:15:45.943: E/AndroidRuntime(17506): FATAL EXCEPTION: main
01-27 15:15:45.943: E/AndroidRuntime(17506): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.portfoliomanager/com.example.portfoliomanager.stockmanager}: java.lang.NullPointerException
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2137)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.app.ActivityThread.access$600(ActivityThread.java:141)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.os.Handler.dispatchMessage(Handler.java:99)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.os.Looper.loop(Looper.java:137)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.app.ActivityThread.main(ActivityThread.java:5103)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at java.lang.reflect.Method.invokeNative(Native Method)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at java.lang.reflect.Method.invoke(Method.java:525)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at dalvik.system.NativeStart.main(Native Method)
01-27 15:15:45.943: E/AndroidRuntime(17506): Caused by: java.lang.NullPointerException
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:235)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:224)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:164)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at com.example.portfoliomanager.Database.<init>(Database.java:17)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at com.example.portfoliomanager.stockmanager.<init>(stockmanager.java:14)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at java.lang.Class.newInstanceImpl(Native Method)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at java.lang.Class.newInstance(Class.java:1130)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
01-27 15:15:45.943: E/AndroidRuntime(17506):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2128)
01-27 15:15:45.943: E/AndroidRuntime(17506):    ... 11 more
0

下面是我的代碼。

數據庫類

public class Database extends SQLiteOpenHelper{

    private static  String dbname="Manager";
    private static int dbversion=2;
    SQLiteDatabase db;

    public Database(Context context) {

        super(context, dbname, null, dbversion);
        // TODO Auto-generated constructor stub
        db=this.getWritableDatabase();
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        StockTable st=new StockTable();
        db.execSQL(st.stocktable);
        }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub

    }

}

調用數據庫的活動類。

public class stockmanager extends Activity{

    String getentry=null;
    Database d=new Database(this);
    StockTable st=new StockTable();


    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.stockmanager);

    final Button AddStock=(Button) findViewById(R.id.button1);
        final EditText entry=(EditText) findViewById(R.id.editText1);
        final Button BroDetail=(Button) findViewById(R.id.button2);

        AddStock.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                getentry=entry.getText().toString();
                d.db.insert(st.tablename, null,st.insert());


            }
        });
                }
}

最后是表創建類。

public class StockTable {

final String tablename="StockTable";
private String column1="Stock_ID";
private String column2="StockName";

stockmanager sm=new stockmanager();

final String stocktable = "CREATE TABLE " + tablename + 
            " (" + column1+ " INTEGER PRIMARY KEY , " + column2 + " TEXT) ";

public ContentValues insert(){

    ContentValues cvi=new ContentValues();
    for(int i=0;i<=sm.getentry.length();i++)
    {
        cvi.put(column1, 1);
        cvi.put(column2,sm.getentry);
                    }

    return cvi;
}

public void delete(){


}

}       

我被困了幾個小時,請幫助我解決這個問題。

您可能還有其他問題,但是現在是這樣:

Database d=new Database(this);

您在“ this”構造之前初始化“ d”。 像這樣將初始化器移動到onCreate:

d=new Database(this);

並且在StockTable類中,您還在活動初始​​化之前對其進行引用(“ stockmanager”不存在並且沒有引用);

您可能應該看一些關於數據庫創建和使用過程的教程。 這是一個: http : //hmkcode.com/android-simple-sqlite-database-tutorial/

還有一個: http : //examples.javacodegeeks.com/android/core/database/sqlite/sqlitedatabase/android-sqlite-example/

暫無
暫無

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

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