在Android中使用数据库,在一些情况下,需要导进一个已经有数据的数据库,然后在程序中去调用它,来实现我们的功能。
比如在一个查询信用卡归属银行的小demo中,在输入框输入信用卡的前6位号码(这6位号码决定了信用卡的归属银行),点击查询按钮,就可以将其对应的银行给显示出来。
而卡表中的数据结构如下:
下面我们来看看,程序中是如何实现这个功能的。
在Asset文件夹下面放上我们的数据库:
在这个类中,我们要实现以下几个功能:
2.1)要将数据库从assets 文件夹复制到手机自身的存储当中去,即 /data/data/package/databases/。
public void copyDatabase(){ String databasePath = mContext.getApplicationContext().getFilesDir().getAbsolutePath(); databasePath = databasePath.substring(0, databasePath.lastIndexOf("/")) + "/databases"; mDatabasePath = databasePath + "/" + DB_NAME; File dir = new File(databasePath); if(!dir.exists()){ dir.mkdir(); } File file = new File(mDatabasePath); if(!file.exists() || file.length() == 0){ try { InputStream is = mContext.getAssets().open("database/"+DB_NAME); FileOutputStream fos = new FileOutputStream(mDatabasePath); byte[] buffer = new byte[8192]; int count = 0; while ((count = is.read(buffer)) > 0) { fos.write(buffer, 0, count); } fos.close(); is.close(); } catch (IOException e) { e.printStackTrace(); } } }在上面这个方法中,
a)首先找出数据库在内存中存放的位置,即"/data/data/包名/databases/"下面,并创建对应的文件,如下:
b)利用Context类的getAssets方法获得AssetManager,然后调用其open方法,将对应路径下的数据库打开,并写到上一步找出来的文件中去。
2.2)创建两个方法,一个用来打开数据库,一个用来关闭数据库,如下:
private void openDatabase(){ Log.v(TAG, "Open DataBase : " + mDatabasePath); mCreditCardDb = SQLiteDatabase.openDatabase(mDatabasePath, null,SQLiteDatabase.NO_LOCALIZED_COLLATORS); } private void closeDatabase() { SQLiteDatabase.releaseMemory(); mCreditCardDb.close(); }
2.3)剩下的就是对数据库表的操作了,根据前6位卡号查出所属的银行:
public String getBankByCreditCardNumber(String creditCardNumber){ String sql = "select * from t_bank where card_bin = ? "; String bankName = ""; openDatabase(); Cursor cursor = mCreditCardDb.rawQuery(sql, new String[] {creditCardNumber}); if(cursor == null){ Log.e(TAG, "Cursor is null."); }else if(!cursor.moveToFirst()){ Log.e(TAG, "Cursor has no records."); }else{ bankName = cursor.getString(cursor.getColumnIndex(COL_BANK_NAME)); } closeDatabase(); return bankName; }
mCreditCardDb = new CreditCardDb(this); mCreditCardDb.copyDatabase();
class CheckCreditCard extends AsyncTask<String, Void, String>{ protected void onPostExecute(String result){ tvBankName.setText(result); } @Override protected String doInBackground(String... params) { String creditCardNumber = params[0]; String bankName = ""; if(creditCardNumber.length() >= 6){ bankName = mCreditCardDb.getBankByCreditCardNumber(creditCardNumber.substring(0,6)); } return bankName; } }