Потеря данных при переключении классов в Blackberry - PullRequest
1 голос
/ 16 сентября 2011

Я включил базу данных в свое приложение Blackberry. Когда я запускаю приложение, база данных строится, и она вставляет значения в базу данных. Однако, когда я изменяю класс, т.е. использую этот

        HelloBlackBerryScreen bbScreen = new HelloBlackBerryScreen();
        UiApplication.getUiApplication().pushScreen(bbScreen);
        this.invalidate();

когда я перезагружаю предыдущий класс, я получаю это:

 [0.0] FileIO:fileinfo start 5e2
 [0.0] FileIO:info by name complete 5e2
 [0.0] FileIO:fileinfo start 5e3
 [0.0] FileIO:info by name complete 5e3
 [0.0] FileIO:open start 5e4
 [0.0] FileIO:open complete 5e4
 [0.0] FileSystem:bad open status 12
 [0.0] File system error (12)read error here
 [0.0] No stack trace

Когда приложение запускается изначально, оно прекрасно читает базу данных, и определенные значения загружаются в соответствующие области, затем я переключаюсь на другой класс, который также может получить доступ к базе данных, а затем переключаюсь обратно на первый класс получите эту ошибку. Я не закрываю базу данных должным образом, когда иду в следующий класс?

Вот код, который я использую для получения значений базы данных:

public void getValues(){
        try {
            URI uri = URI.create("file:///SDCard/Databases/" + "database2.db");
            sqliteDB = DatabaseFactory.open(uri);
            Statement st = sqliteDB.createStatement("SELECT Signauto,SaveP FROM options");
            st.prepare();
            Cursor c = st.getCursor();
            Row r;
            int i = 0;
            while(c.next()) 
            {
                r = c.getRow();
                i++;
                System.out.println(r.getString(0) + "HERE");
                System.out.println(r.getString(1) + "HERE");
                if(r.getString(0).equals("true")){
                    tickBoxes[1] = true;
                    //signAuto();

                }
                else{
                    tickBoxes[1] = false;
                }
                if(r.getString(1).equals("true")){
                    tickBoxes[0] = true;
                    setUserPass();
                }
                else{
                    tickBoxes[0] = false;
                }

            }

            if (i==0)
            {
                System.out.println("No data in the options table.");
            }
            st.close();
            sqliteDB.close();
        }

        catch ( Exception e ) {
            System.out.println( e.getMessage() + "read error here");
            e.printStackTrace();
        }
    }

1 Ответ

2 голосов
/ 16 сентября 2011

Несколько вещей, чтобы попробовать.

Переместите операторы close в свои собственные блоки catch, чтобы исключение в одном не мешало закрытию другого.

    } finally {
        try {
            if (st!=null) st.close();
        } catch (DatabaseException e) {
            System.out.println( e.getMessage() + "read error here");
        }
        try {
            if (sqliteDB!=null) sqliteDB.close();
        } catch (DatabaseIOException e) {
            System.out.println( e.getMessage() + "read error here");
        }
    }

Также синхронизируйте ваши методы доступа к БД, чтобы один не вызывал исключение в другом.

...