我需要使用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);
}
}
}
你爲什麼不告訴我們你想要完成什麼?你想傳遞一個值來執行查詢嗎?如果你正試圖從SQLiteOpenHelper獲取(),那麼有些東西是不對的,因爲這個類應該完全脫離你的視圖。你的主要活動應該調用你的SQLiteOpenHelper類,而不是相反。 – Jack
我需要根據變量值對數據庫的返回進行排序。因此,例如,如果用戶單擊主屏幕上的按鈕以按數字排序或按名稱排序。 – Adam