رفتن به مطلب
انجمن اندروید ایران | آموزش برنامه نویسی اندروید و موبایل
  • android.png.1fab383bc8500cd93127cebc65b1dcab.png

مشکل استفاده از دیتابیس خارجی


پست های پیشنهاد شده

با سلام.

من می خواستم یک دیکشنری بنویسم برای پروژه کارشناسی.از مدیران انجمن که تجربه کار با دیتابیس خارجی رو دارن درخواست کمک دارم.من مراحل زیر رو رفتم اما به مشکل برخوردم:

1-دیتابیس رو درون پوشه assets قرار دادم 

2-بعد درون برنامه اون رو در مسیر /data/data/com.omid.dics کپی کردم.

3-دیتابیس رو باز کردم.

تا اینجا مشکلی نداشتم اما وقتی روی دیتابیس  query میزنم ارور میده و میگه no such table لطفا کمک کنید برای پروژه کارشناسی می خوام اینرو بدم.

اگه لازم دیدید بگید تا کد رو قرار بدم.

لینک ارسال
به اشتراک گذاری در سایت های دیگر

این مشکل در رابطه با درست کپی نشدن دیتابیس میباشد،

لطفا کلاسی که دیتابیس را کپی  میکنید قرار دهید تا مشکل برطرف گردد

لینک ارسال
به اشتراک گذاری در سایت های دیگر

سلام آقای سرسیفی .من وقتی برنامه رو پاک کردم و دوباره نصب کردمدوباره به مشکل قبل برخورد کردم.کد رو قرار می دم خواهشا یک نگاه بندازید شما و همه دوستان.

public class DataBaseHelper extends SQLiteOpenHelper {   private static String  DB_PATH;   private static String  DB_NAME = "data.db";   private SQLiteDatabase myDataBase;   private Context        mycontext;   public DataBaseHelper(Context context) {       super(context, DB_NAME, null, 1);       mycontext = context;       DB_PATH = "/data/data/" + context.getPackageName() + "/databases/";   }   public void createDataBase() throws IOException {       boolean dbExist = checkDataBase();       if ( !dbExist) {           this.getReadableDatabase();           copyDataBase();       }   }   private boolean checkDataBase() {       SQLiteDatabase checkDB = null;       try {           String myPath = DB_PATH + DB_NAME;           checkDB = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READONLY);       }       catch (SQLiteException e) {           Toast.makeText(mycontext, e.toString(), Toast.LENGTH_LONG).show();       }       if (checkDB != null) {           checkDB.close();       }       return checkDB != null ? true : false;   }   private void copyDataBase() {       File f = new File(DB_PATH);       if ( !f.exists()) {           f.mkdirs();           try {               f.createNewFile();           }           catch (IOException e) {               // TODO Auto-generated catch block               e.printStackTrace();           }       }       InputStream myInput = null;       try {           myInput = mycontext.getAssets().open(DB_NAME);       }       catch (IOException e) {           // TODO Auto-generated catch block           Toast.makeText(mycontext, e.toString(), Toast.LENGTH_LONG).show();       }       String outFileName = DB_PATH + DB_NAME;       OutputStream myOutPut = null;       try {           myOutPut = new FileOutputStream(outFileName);       }       catch (FileNotFoundException e) {           // TODO Auto-generated catch block           Toast.makeText(mycontext, e.toString(), Toast.LENGTH_LONG).show();       }       byte[] buffer = new byte[1024];       int length;       try {           while ((length = myInput.read(buffer)) > 0) {               myOutPut.write(buffer, 0, length);               // myOutPut.flush();           }       }       catch (IOException e) {           // TODO Auto-generated catch block           Toast.makeText(mycontext, e.toString(), Toast.LENGTH_LONG).show();       }       try {           myOutPut.flush();           myOutPut.close();           myInput.close();       }       catch (IOException e) {           // TODO Auto-generated catch block           Toast.makeText(mycontext, e.toString(), Toast.LENGTH_LONG).show();       }   }   public void openDatabse() {       try {           String myPath = DB_PATH + DB_NAME;           myDataBase = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READONLY);       }       catch (SQLException e) {           Toast.makeText(mycontext, e.toString(), Toast.LENGTH_LONG).show();       }   }   @Override   public synchronized void close() {       if (myDataBase != null) {           myDataBase.close();       }       super.close();   }   @Override   public void onCreate(SQLiteDatabase arg0) {       // TODO Auto-generated method stub   }   @Override   public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {       // TODO Auto-generated method stub   }}
لینک ارسال
به اشتراک گذاری در سایت های دیگر

به گفتگو بپیوندید

هم اکنون می توانید مطلب خود را ارسال نمایید و بعداً ثبت نام کنید. اگر حساب کاربری دارید، برای ارسال با حساب کاربری خود اکنون وارد شوید .

مهمان
ارسال پاسخ به این موضوع...

×   شما در حال چسباندن محتوایی با قالب بندی هستید.   حذف قالب بندی

  تنها استفاده از 75 اموجی مجاز می باشد.

×   لینک شما به صورت اتوماتیک جای گذاری شد.   نمایش به صورت لینک

×   محتوای قبلی شما بازگردانی شد.   پاک کردن محتوای ویرایشگر

×   شما مستقیما نمی توانید تصویر خود را قرار دهید. یا آن را اینجا بارگذاری کنید یا از یک URL قرار دهید.

×
×
  • اضافه کردن...