簡體   English   中英

無法在SQLite Android Eclipse中創建超過2列?

[英]Unable to make more than 2 columns in SQLite Android Eclipse?

為什么當我有3列以上時,應用程序崩潰? 我嘗試通過注釋掉一列來調試它,它運行完美。 對其進行更多調試之后,我發現問題可能出在“ populateListview”上,因為我能夠運行該應用程序,但現在它不顯示任何內容。 您為什么認為我不能用超過3列來運行它?

這是我的dbAdapter:

// Field Names:
public static final String KEY_ROWID = "_id";
public static final String KEY_INGREDIENTNAME = "ingredientname";
public static final String KEY_IMAGE = "image";
public static final String KEY_DETAILS = "details";

public static final String[] ALL_KEYS = new String[] {KEY_ROWID, KEY_INGREDIENTNAME, KEY_IMAGE, KEY_DETAILS};

// Column Numbers for each Field Name:
public static final int COL_ROWID = 0;
public static final int COL_INGREDIENTNAME = 1;
public static final int COL_IMAGE = 2;
public static final int COL_DETAILS = 3;

//SQL statement to create database
private static final String DATABASE_CREATE_SQL = 
        "CREATE TABLE " + DATABASE_TABLE 
        + " (" + KEY_ROWID + " INTEGER PRIMARY KEY AUTOINCREMENT, "
        + KEY_INGREDIENTNAME + " TEXT NOT NULL, "
        + KEY_IMAGE + " TEXT"
        + KEY_DETAILS + " TEXT"
        + ");";

// Add a new set of values to be inserted into the database.
public long insertRow(String ingredientname, String image, String detailsValue) {
    ContentValues initialValues = new ContentValues();
    initialValues.put(KEY_INGREDIENTNAME, ingredientname);
    initialValues.put(KEY_IMAGE, image);
    initialValues.put(KEY_DETAILS, detailsValue);

    // Insert the data into the database.
    return db.insert(DATABASE_TABLE, null, initialValues);
}

// Return all data in the database.
public Cursor getAllRows() {
    String where = null;
    Cursor c =  db.query(true, DATABASE_TABLE, ALL_KEYS, where, null, null, null, null, null);
    if (c != null) {
        c.moveToFirst();

    }
    return c;
}

這是我的populateListView代碼:

    private void populateListView() {
    Cursor cursor = myDb.getAllRows();
    String[] fromFieldNames = new String[] { //DBAdapter.KEY_ROWID,
            DBAdapter.KEY_INGREDIENTNAME };
    int[] toViewIDs = new int[] { //R.id.textViewItemNumber,
            R.id.textViewItemTask };
    SimpleCursorAdapter myCursorAdapter;
    myCursorAdapter = new SimpleCursorAdapter(getBaseContext(),
            R.layout.item_layout, cursor, fromFieldNames, toViewIDs, 0);
    ListView myList = (ListView) findViewById(R.id.listViewTask);
    myList.setAdapter(myCursorAdapter);
}

您在這里錯過逗號:

private static final String DATABASE_CREATE_SQL = 
        "CREATE TABLE " + DATABASE_TABLE 
        + " (" + KEY_ROWID + " INTEGER PRIMARY KEY AUTOINCREMENT, "
        + KEY_INGREDIENTNAME + " TEXT NOT NULL, "
        + KEY_IMAGE + " TEXT"
        + KEY_DETAILS + " TEXT"
        + ");";

它應該是

private static final String DATABASE_CREATE_SQL = 
        "CREATE TABLE " + DATABASE_TABLE 
        + " (" + KEY_ROWID + " INTEGER PRIMARY KEY AUTOINCREMENT, "
        + KEY_INGREDIENTNAME + " TEXT NOT NULL, "
        + KEY_IMAGE + " TEXT,"
        + KEY_DETAILS + " TEXT"
        + ");";

暫無
暫無

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

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