私は、データがsqliteからフェッチされるアンドロイドアプリケーションに取り組んでいます。ここでは、文字列値を挿入して取り出すことができましたが、今はイメージを挿入して取得したいのですか?誰でも私にこれを手伝うことができますか?sqliteデータベースからイメージを挿入および取得する方法は?
これは、DB、列を作成してデータを挿入する私のDBAdapterクラスです。
public class DBAdapter {
public static final String KEY_ROWID = "_id";
public static final String Product = "product";
public static final String Price = "price";
public static final String InStock = "instock";
public static final String OutOfStock = "outofstock";
//public static final String imgs = "img";
private static final String TAG = "CountriesDbAdapter";
private DatabaseHelper mDbHelper;
private SQLiteDatabase mDb;
private static final String DATABASE_NAME = "World";
private static final String SQLITE_TABLE = "Country";
private static final int DATABASE_VERSION = 1;
private final Context mCtx;
private static final String DATABASE_CREATE =
"CREATE TABLE if not exists " + SQLITE_TABLE + " (" +
KEY_ROWID + " integer PRIMARY KEY autoincrement," +
Product + "," +
Price + "," +
InStock + "," +
OutOfStock + "," +
" UNIQUE (" + Product +"));";
private static class DatabaseHelper extends SQLiteOpenHelper {
DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
Log.w(TAG, DATABASE_CREATE);
db.execSQL(DATABASE_CREATE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
Log.w(TAG, "Upgrading database from version " + oldVersion + " to "
+ newVersion + ", which will destroy all old data");
db.execSQL("DROP TABLE IF EXISTS " + SQLITE_TABLE);
onCreate(db);
}
}
public DBAdapter(Context ctx) {
this.mCtx = ctx;
}
public DBAdapter open() throws SQLException {
mDbHelper = new DatabaseHelper(mCtx);
mDb = mDbHelper.getWritableDatabase();
return this;
}
public void close() {
if (mDbHelper != null) {
mDbHelper.close();
}
}
public long createCountry(String product, String price,
String instock, String outofstock) {
ContentValues initialValues = new ContentValues();
initialValues.put(Product, product);
initialValues.put(Price, price);
initialValues.put(InStock, instock);
initialValues.put(OutOfStock, outofstock);
// initialValues.put(imgs,img);
return mDb.insert(SQLITE_TABLE, null, initialValues);
}
public boolean deleteAllCountries() {
int doneDelete = 0;
doneDelete = mDb.delete(SQLITE_TABLE, null , null);
Log.w(TAG, Integer.toString(doneDelete));
return doneDelete > 0;
}
/* public Cursor fetchCountriesByName(String inputText) throws SQLException {
Log.w(TAG, inputText);
Cursor mCursor = null;
if (inputText == null || inputText.length() == 0) {
mCursor = mDb.query(SQLITE_TABLE, new String[] {KEY_ROWID,
Product, Price, InStock, OutOfStock},
null, null, null, null, null);
}
else {
mCursor = mDb.query(true, SQLITE_TABLE, new String[] {KEY_ROWID,
Product, Price, InStock, OutOfStock},
Product + " like '%" + inputText + "%'", null,
null, null, null, null);
}
if (mCursor != null) {
mCursor.moveToFirst();
}
return mCursor;
}*/
public Cursor fetchAllCountries() {
Cursor mCursor = mDb.query(SQLITE_TABLE, new String[] {KEY_ROWID,
Product, Price, InStock, OutOfStock},
null, null, null, null, null);
if (mCursor != null) {
mCursor.moveToFirst();
}
return mCursor;
}
public void insertSomeCountries() {
createCountry("NOKIA X201","10,000","InStock","OutOfStock");
createCountry("SAMSUNG Galaxy Note","30,000","OutOfStock","InStock");
createCountry("IPHONE 6S+","65,000","InStock","OutOfStock");
createCountry("MOTO G2","12,999","InStock","OutOfStock");
createCountry("IBALL ANDY", "11,000", "OutOfStock", "InStock");
createCountry("MOTO G4", "13,999", "InStock", "OutOfStock");
createCountry("SONY XPERIA", "8,000", "OutOfStock", "InStock");
}
}