2011-10-17 65 views
0

我需要使用getIntent,但不能這樣做,因爲從我所做的事情來看,它不是SQLiteOpenHelper的構造函數,而getIntent需要從在onCreate內。onCreate不是SQLiteOpenHelper的構造函數,但我需要它getIntet

這就是這種情況,我將如何從SQLiteOpenHelper中訪問它?

基本上,我試圖從SQLiteOpenHelper中得到下面的代碼,但是有麻煩。

 public void onCreate(Bundle savedInstanceState) { 
     onCreate(savedInstanceState); 
     sortTypePassed=getIntent().getStringExtra(SmithRockScreenActivity.SORT_TYPE_VAR); 
    } 

我想根據字符串的值做一個查詢排序的數據庫。像這樣:

public Cursor getCursor() { 



    SQLiteQueryBuilder queryBuilder = new SQLiteQueryBuilder(); 

    queryBuilder.setTables(TABLE_NAME); 

    String[] asColumnsToReturn = new String[] { COLUMN_ID, COLUMN_TITLE, COLUMN_YDSRATING, COLUMN_ROUTETYPE, COLUMN_AREA, COLUMN_ROUTEVIDEO, COLUMN_ROUTEDESCRIPTION}; 

    if (sortTypePassed.equals("nameSort")) { 

     Cursor mCursor = queryBuilder.query(dbSqlite, asColumnsToReturn, null, 
       null, null, null, "route_name ASC"); 

     return mCursor; 

    } else { 

     Cursor mCursor = queryBuilder.query(dbSqlite, asColumnsToReturn, null, 
       null, null, null, "yds_rating ASC"); 

     return mCursor; 

    } 

這裏是它的整個長度代碼:

package com.pocketbeta; 


import java.io.FileOutputStream; 
import java.io.IOException; 
import java.io.InputStream; 
import java.io.OutputStream; 
import java.util.Locale; 

import android.app.Activity; 
import android.content.Context; 
import android.database.Cursor; 
import android.database.SQLException; 
import android.database.sqlite.SQLiteException; 
import android.database.sqlite.SQLiteOpenHelper; 
import android.database.sqlite.SQLiteDatabase; 
import android.database.sqlite.SQLiteQueryBuilder; 
import android.os.Bundle; 
import android.util.Log; 


class SmithRockDatabase extends SQLiteOpenHelper { 

public String sortTypePassed = "null"; 

private static final String DATABASE_PATH = "/data/data/com.pocketbeta/databases/"; 
private static final String DATABASE_NAME="smithrockdb.db"; 
private static final int SCHEMA_VERSION=1; 
public static final String TABLE_NAME = "SmithRockRoutes"; 
public static final String COLUMN_ID = "_id"; 
public static final String COLUMN_TITLE = "route_name"; 
public static final String COLUMN_YDSRATING = "yds_rating"; 
public static final String COLUMN_QUALITY = "quality"; 
public static final String COLUMN_IMAGE = "route_photo"; 
public static final String COLUMN_ROUTEVIDEO = "route_video"; 
public static final String COLUMN_TICKLIST = "ticklist"; 
public static final String COLUMN_AREA = "area"; 
public static final String COLUMN_ROUTETYPE = "route_type"; 
public static final String COLUMN_ROUTEDESCRIPTION = "route_description"; 

public SQLiteDatabase dbSqlite; 

private final Context myContext; 

public SmithRockDatabase(Context context) { 
    super(context, DATABASE_NAME, null, SCHEMA_VERSION); 
    this.myContext = context; 
    // check if exists and copy database from resource 
    //createDB(); 
} 


@Override 
public void onCreate(SQLiteDatabase db) { 
    // check if exists and copy database from resource 

} 

@Override 
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 

} 
public void createDatabase() { 
    createDB(); 
} 

private void createDB() { 

    boolean dbExist = DBExists(); 

    if (!dbExist) { 

     //By calling this method we create an empty database into the default system location 
     //We need this so we can overwrite that database with our database. 
     this.getReadableDatabase(); 
     //now we copy the database we included! 
     copyDBFromResource(); 


    } 



}  

private boolean DBExists() { 

    SQLiteDatabase db = null; 

    try { 
     String databasePath = DATABASE_PATH + DATABASE_NAME; 
     db = SQLiteDatabase.openDatabase(databasePath, null, 
       SQLiteDatabase.OPEN_READWRITE); 
     db.setLocale(Locale.getDefault()); 
     db.setLockingEnabled(true); 
     db.setVersion(1); 



    } catch (SQLiteException e) { 

     Log.e("SqlHelper", "database not found"); 

    } 

    if (db != null) { 


     db.close(); 

    } 


    return db != null ? true : false; 
} 

private void copyDBFromResource() { 

    InputStream inputStream = null; 
    OutputStream outStream = null; 
    String dbFilePath = DATABASE_PATH + DATABASE_NAME; 

    try { 

     inputStream = myContext.getAssets().open(DATABASE_NAME); 

     outStream = new FileOutputStream(dbFilePath); 

     byte[] buffer = new byte[1024]; 
     int length; 
     while ((length = inputStream.read(buffer)) > 0) { 
      outStream.write(buffer, 0, length); 
     } 

     outStream.flush(); 
     outStream.close(); 
     inputStream.close(); 

    } catch (IOException e) { 

     throw new Error("Problem copying database from resource file."); 

    } 

} 

public void openDataBase() throws SQLException { 

    String myPath = DATABASE_PATH + DATABASE_NAME; 
    dbSqlite = SQLiteDatabase.openDatabase(myPath, null, 
      SQLiteDatabase.OPEN_READWRITE); 

} 

@Override 
public synchronized void close() { 

    if (dbSqlite != null) 
    { 
     dbSqlite.close(); 
    } 
    super.close(); 

} 

// NEED TO GET THIS CODE TO WORK TO BRING IN VALUE FROM OTHER INTENT!!!!!!!!!!!!!!!!!! 

// public void onCreate(Bundle savedInstanceState) { 
// onCreate(savedInstanceState); 
// sortTypePassed=getIntent().getStringExtra(SmithRockScreenActivity.SORT_TYPE_VAR); 
//} 
// } 


public Cursor getCursor() { 



    SQLiteQueryBuilder queryBuilder = new SQLiteQueryBuilder(); 

    queryBuilder.setTables(TABLE_NAME); 

    String[] asColumnsToReturn = new String[] { COLUMN_ID, COLUMN_TITLE, COLUMN_YDSRATING, COLUMN_ROUTETYPE, COLUMN_AREA, COLUMN_ROUTEVIDEO, COLUMN_ROUTEDESCRIPTION}; 

    if (sortTypePassed.equals("nameSort")) { 

     Cursor mCursor = queryBuilder.query(dbSqlite, asColumnsToReturn, null, 
       null, null, null, "route_name ASC"); 

     return mCursor; 

    } else { 

     Cursor mCursor = queryBuilder.query(dbSqlite, asColumnsToReturn, null, 
       null, null, null, "yds_rating ASC"); 

     return mCursor; 

    } 

} 


public String getName(Cursor c) { 


    return(c.getString(1)); 

} 

public String getRating(Cursor c) { 
    return(c.getString(2)); 
} 
public String getArea(Cursor c) { 
    return(c.getString(4)); 
} 
public String getRouteVideo(Cursor c) { 
    return(c.getString(5)); 
} 
public String getRouteDescription(Cursor c) { 
    return(c.getString(6)); 
} 

public String getRouteType(Cursor c) { 

    String routeValue=""; 
    routeValue=(c.getString(3)); 
    String noSelection = ""; 

    if (routeValue != null) { 
     return c.getString(3); 

    } else { 
     return(noSelection); 

    } 


} 

}

+0

你爲什麼不告訴我們你想要完成什麼?你想傳遞一個值來執行查詢嗎?如果你正試圖從SQLiteOpenHelper獲取(),那麼有些東西是不對的,因爲這個類應該完全脫離你的視圖。你的主要活動應該調用你的SQLiteOpenHelper類,而不是相反。 – Jack

+0

我需要根據變量值對數據庫的返回進行排序。因此,例如,如果用戶單擊主屏幕上的按鈕以按數字排序或按名稱排序。 – Adam

回答

0

既然如此,我將如何訪問它從SQLiteOpenHelper內?

理想情況下,您無法從SQLiteOpenHelper訪問getIntent()。你在SQLiteOpenHelper上實現了一個構造函數(提示:你已經有了一個),並且傳遞它所需要的任何數據。理想情況下,不是涉及傳遞活動,而是值從任何地方獲得活動(例如,Intent演員)。

+0

是的,我需要基於外部變量對SQLiteOpenHelper中的數據進行排序。我必須編寫3個不同的SQLitOpenHelpers來對3種不同的樣式進行排序。如果我可以在SQLiteHelper進行排序期間進行變量檢查並進行相應的排序,則可以避免編寫並引用3個不同的幫助程序。 – Adam

+0

@Adam:然後將該值作爲參數傳遞給構造函數或調用的任何方法,以使其執行涉及排序的查詢。 – CommonsWare

+0

@Adam爲什麼不有一個單獨的方法,如getItems(string sortOrder)?用你正在返回的任何對象替換項目(getUsers,getPages等)。您不限於在構造函數中傳遞值。 – Jack

相關問題