Форум программистов, компьютерный форум CyberForum.ru

Программирование Android

Войти
Регистрация
Восстановить пароль
 
Worldmen
2 / 2 / 1
Регистрация: 31.08.2013
Сообщений: 198
Завершенные тесты: 1
#1

Подключиться к готовой базе данных - Программирование Android

29.09.2015, 21:45. Просмотров 344. Ответов 2
Метки нет (Все метки)

Давно делал программку, из нее взял код. БД лежит в папке проекта \src\main\res\assets\english.sqlite
В коде она копируется с помощью метода ConectBD.copyDataBase и в логе видно что она там есть (если я прав).
Ошибка выводится при подключении к БД в строке EngRusActivity метода onCreate:
Java
1
EnglishWords(database);
Лог (лог не сначала - ограничение на символы):
Кликните здесь для просмотра всего текста

09-29 18:28:18.825 11518-11518/com.stetsenko.english02 W/dalvikvm﹕ VFY: unable to resolve virtual method 369: Landroid/content/res/Resources;.getDrawableForDensity (IILandroid/content/res/Resources$ThemeLandroid/graphics/drawable/Drawable;
09-29 18:28:18.825 11518-11518/com.stetsenko.english02 D/dalvikvm﹕ VFY: replacing opcode 0x6e at 0x0002
09-29 18:28:18.905 11518-11518/com.stetsenko.english02 I/class com.stetsenko.english02.ConectBD﹕ База данных уже существует
09-29 18:28:18.925 11518-11518/com.stetsenko.english02 E/Мой лог:﹕ MainActivity.db_NAME=english.sqlite
09-29 18:28:18.956 11518-11518/com.stetsenko.english02 I/SqliteDatabaseCpp﹕ sqlite returned: error code = 1, msg = no such table: words, db=//data//data//com.stetsenko.english02//databases//english.sqlite
09-29 18:28:18.956 11518-11518/com.stetsenko.english02 E/class com.stetsenko.english02.EngRusActivity﹕ Ошибка выбора данных
09-29 18:28:18.965 11518-11518/com.stetsenko.english02 D/AndroidRuntime﹕ Shutting down VM
09-29 18:28:18.965 11518-11518/com.stetsenko.english02 W/dalvikvm﹕ threadid=1: thread exiting with uncaught exception (group=0x409bf1f8)
09-29 18:28:18.995 11518-11518/com.stetsenko.english02 E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.Error: Ошибка выбора данных!
at com.stetsenko.english02.EngRusActivity.EnglishWords(EngRusActivity.java:102)
at com.stetsenko.english02.EngRusActivity.onCreate(EngRusActivity.java:42)
at android.app.Activity.performCreate(Activity.java:4466)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
at android.app.ActivityThread.access$600(ActivityThread.java:123)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4424)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
at dalvik.system.NativeStart.main(Native Method)
09-29 18:28:19.235 11518-11524/com.stetsenko.english02 I/dalvikvm﹕ threadid=3: reacting to signal 3
09-29 18:28:19.285 11518-11524/com.stetsenko.english02 I/dalvikvm﹕ Wrote stack traces to '/data/anr/traces.txt'
09-29 18:28:19.715 11518-11524/com.stetsenko.english02 I/dalvikvm﹕ threadid=3: reacting to signal 3
09-29 18:28:19.855 11518-11524/com.stetsenko.english02 I/dalvikvm﹕ Wrote stack traces to '/data/anr/traces.txt'
09-29 18:28:20.634 11518-11524/com.stetsenko.english02 I/dalvikvm﹕ threadid=3: reacting to signal 3
09-29 18:28:20.666 11518-11524/com.stetsenko.english02 I/dalvikvm﹕ Wrote stack traces to '/data/anr/traces.txt'
09-29 18:28:21.345 11518-11524/com.stetsenko.english02 I/dalvikvm﹕ threadid=3: reacting to signal 3
09-29 18:28:21.385 11518-11524/com.stetsenko.english02 I/dalvikvm﹕ Wrote stack traces to '/data/anr/traces.txt'
09-29 18:28:21.515 11518-11518/com.stetsenko.english02 I/Process﹕ Sending signal. PID: 11518 SIG: 9

ConectBD.java
Кликните здесь для просмотра всего текста
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
package com.stetsenko.english02;
 
 
import android.content.Context;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;
 
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
 
public class ConectBD extends SQLiteOpenHelper {
    //Путь к папке с базами на устройстве
    public static String DB_PATH;
    //Имя файла с базой
    public static String DB_NAME;
    public SQLiteDatabase database;
    public final Context context;
 
    public SQLiteDatabase getDb() {
        return database;
    }
 
    public ConectBD(Context context, String databaseName, CursorFactory factory, int version) {
        //super(context, name, factory, version);
        super(context, databaseName, null, 1);
        this.context = context;
        //Составим полный путь к базам для вашего приложения
        String packageName = context.getPackageName();
        DB_PATH = String.format("//data//data//%s//databases//", packageName);
        DB_NAME = databaseName;
        openDataBase();
    }
 
    //Создаст базу, если она не создана
    public void createDataBase()
    {
        boolean dbExist = checkDataBase();
        if (!dbExist) {
            this.getReadableDatabase();
            try {
                copyDataBase();
            } catch (IOException e) {
                Log.e(this.getClass().toString(), "Ошибка копирования");
                throw new Error("Ошибка копирования БД!");
            }
        } else {
            Log.i(this.getClass().toString(), "База данных уже существует");
        }
    }
 
    //Проверка существования базы данных
    private boolean checkDataBase()
    {
        SQLiteDatabase checkDb = null;
        try {
            String path = DB_PATH + DB_NAME;
            checkDb = SQLiteDatabase.openDatabase(path, null,   SQLiteDatabase.OPEN_READONLY);
        } catch (SQLException e) {
            Log.e(this.getClass().toString(), "Ошибка! БД открыта");
        }
        //Ардроид не любит утечки ресурсов, все должно закрываться
        if (checkDb != null) {
            checkDb.close();
        }
        return checkDb != null;
    }
 
    //Метод копирования базы
    private void copyDataBase() throws IOException
    {
        // Открываем поток для чтения из уже созданной нами БД источник в assets
        InputStream externalDbStream = context.getAssets().open(DB_NAME);
 
        // Путь к уже созданной пустой базе в андроиде
        String outFileName = DB_PATH + DB_NAME;
 
        // Теперь создадим поток для записи в эту БД побайтно
        OutputStream localDbStream = new FileOutputStream(outFileName);
 
        // Собственно копирование
        byte[] buffer = new byte[1024];
        int bytesRead;
        while ((bytesRead = externalDbStream.read(buffer)) > 0) {
            localDbStream.write(buffer, 0, bytesRead);
        }
        // Мы будем хорошими мальчиками(девочками) и закроем потоки
        localDbStream.close();
        externalDbStream.close();
    }
 
    public SQLiteDatabase openDataBase() throws SQLException
    {
        String path = DB_PATH + DB_NAME;
        if (database == null) {
            createDataBase();
            database = SQLiteDatabase.openDatabase(path, null,  SQLiteDatabase.OPEN_READWRITE);
        }
        return database;
    }
 
    @Override
    public synchronized void close()
    {
        if (database != null) { database.close();   }
        super.close();
    }
 
    @Override
    public void onCreate(SQLiteDatabase db) {}
 
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}
}


Из MainActivity беру только название БД (по кнопке перехожу на EngRusActivity )
Кликните здесь для просмотра всего текста
Java
1
2
3
4
public class MainActivity extends AppCompatActivity implements OnClickListener {
 
    Button btnBegin;
    public static final String db_NAME = "english.sqlite";


С БД работаю от сюда- EngRusActivity:
Кликните здесь для просмотра всего текста
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
package com.stetsenko.english02;
 
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
 
import java.io.IOException;
 
public class EngRusActivity extends AppCompatActivity implements OnClickListener {
 
    TextView EnglishWord;
    EditText RusText;
    Button btnAnswer;
    int countWords;
    int i = 0;
    String[] engWords;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.eng_rus);
 
        EnglishWord = (TextView) findViewById(R.id.englishWord);
        RusText = (EditText) findViewById(R.id.rusText);
        btnAnswer = (Button) findViewById(R.id.btnAnswer);
        btnAnswer.setOnClickListener(this);
 
        ConectBD dbOpenHelper = new ConectBD(this, MainActivity.db_NAME, null, 1);
        Log.e(" Мой лог: ", "MainActivity.db_NAME="+MainActivity.db_NAME);
 
        SQLiteDatabase database = dbOpenHelper.openDataBase();
        //database = dbOpenHelper.getWritableDatabase();
        EnglishWords(database);
        if (engWords.length>0) {
            EnglishWord.setText(engWords[i]);
        }
        i++;
    }
 
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_eng_rus, menu);
        return true;
    }
 
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
 
        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }
 
        return super.onOptionsItemSelected(item);
    }
 
    @Override
    public void onClick(View v) {
        switch (v.getId()){
            // ответ
            case R.id.btnAnswer:
                if (countWords-1 <= i){
                    EnglishWord.setText(engWords[i]);
                    i++;
                }
                break;
            default: break;
        }
    }
 
    private void EnglishWords(SQLiteDatabase db){
        try {
            String sql = "Select wordEn, wordRu From words";
            Cursor crsEnglish;
            crsEnglish = db.rawQuery(sql, null);
            countWords = crsEnglish.getCount();    // кол-во сторок
            engWords = new String[countWords];  // заполняем словами
            int i = 0;
            crsEnglish.moveToFirst();
            if (!crsEnglish.isAfterLast()) {
                do {
                    engWords[i] = crsEnglish.getString(0);
                    i++;
                } while (crsEnglish.moveToNext());
            }
        }catch(Exception e){
            Log.e(this.getClass().toString(), "Ошибка выбора данных");
            throw new Error("Ошибка выбора данных!");
        }
    }
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.09.2015, 21:45
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Подключиться к готовой базе данных (Программирование Android):

Не удается подключиться к базе данных - Программирование Android
public class DisplayActivity extends Activity { ListView list; LinearLayout ll; Button loadBtn; //private...

Как подключиться с базе данных FireBird из Android - Программирование Android
Всем привет, ребят кто нить сталкивался с такой задачей?. Смысл в том, что есть база данных Firebird .FBD, необходимо написать приложение...

Сортировка данных в базе - Программирование Android
А как можно отсортировать данные в базе SqLite?

Подключение к базе данных - Программирование Android
Возник вопрос ,как можно осуществить подключение приложения к базе данных которые располагаются на стороннем сервере?? ? (как брать из их...

Доступ к базе данных - Программирование Android
Здравствуйте. Имеется три активити (MainActivity (основная), Program (программы подготовки) и Speciality (специальности)), база данных...

Подключение к базе данных из ViewPager - Программирование Android
В приложении есть база данных, везде в приложении она работает хорошо, но есть небольшая проблема с ее использованием в ViewPager. При...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Rube
911 / 559 / 88
Регистрация: 13.02.2014
Сообщений: 2,070
30.09.2015, 07:48 #2
no such table: words
Worldmen
2 / 2 / 1
Регистрация: 31.08.2013
Сообщений: 198
Завершенные тесты: 1
30.09.2015, 22:04  [ТС] #3
А если удалить на установленную программу на устройстве и заново запустить, то ругается по другому:
Кликните здесь для просмотра всего текста
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
09-30 18:51:22.884    2298-2298/com.stetsenko.english02 I/dalvikvm﹕ Could not find method android.content.res.Resources.getDrawable, referenced from method android.support.v7.internal.widget.ResourcesWrapper.getDrawable
09-30 18:51:22.914    2298-2298/com.stetsenko.english02 W/dalvikvm﹕ VFY: unable to resolve virtual method 367: Landroid/content/res/Resources;.getDrawable (ILandroid/content/res/Resources$Theme;)Landroid/graphics/drawable/Drawable;
09-30 18:51:22.914    2298-2298/com.stetsenko.english02 D/dalvikvm﹕ VFY: replacing opcode 0x6e at 0x0002
09-30 18:51:22.914    2298-2298/com.stetsenko.english02 I/dalvikvm﹕ Could not find method android.content.res.Resources.getDrawableForDensity, referenced from method android.support.v7.internal.widget.ResourcesWrapper.getDrawableForDensity
09-30 18:51:22.914    2298-2298/com.stetsenko.english02 W/dalvikvm﹕ VFY: unable to resolve virtual method 369: Landroid/content/res/Resources;.getDrawableForDensity (IILandroid/content/res/Resources$Theme;)Landroid/graphics/drawable/Drawable;
09-30 18:51:22.924    2298-2298/com.stetsenko.english02 D/dalvikvm﹕ VFY: replacing opcode 0x6e at 0x0002
09-30 18:51:22.974    2298-2298/com.stetsenko.english02 I/SqliteDatabaseCpp﹕ sqlite returned: error code = 14, msg = cannot open file at line 27701 of [8609a15dfa], db=//data//data//com.stetsenko.english02//databases//english.sqlite
09-30 18:51:22.974    2298-2298/com.stetsenko.english02 I/SqliteDatabaseCpp﹕ sqlite returned: error code = 14, msg = os_unix.c: open() at line 27701 - "" errno=2 path=//data//data//com.stetsenko.english02//databases//english.sqlite, db=//data//data//com.stetsenko.english02//databases//english.sqlite
09-30 18:51:22.974    2298-2298/com.stetsenko.english02 E/SqliteDatabaseCpp﹕ sqlite3_open_v2("//data//data//com.stetsenko.english02//databases//english.sqlite", &handle, 1, NULL) failed
09-30 18:51:23.014    2298-2298/com.stetsenko.english02 E/SQLiteDatabase﹕ Failed to open the database. closing it.
    android.database.sqlite.SQLiteCantOpenDatabaseException: unable to open database file
            at android.database.sqlite.SQLiteDatabase.dbopen(Native Method)
            at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:1013)
            at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:986)
            at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:962)
            at com.stetsenko.english02.ConectBD.checkDataBase(ConectBD.java:62)
            at com.stetsenko.english02.ConectBD.createDataBase(ConectBD.java:42)
            at com.stetsenko.english02.ConectBD.openDataBase(ConectBD.java:100)
            at com.stetsenko.english02.ConectBD.<init>(ConectBD.java:36)
            at com.stetsenko.english02.EngRusActivity.onCreate(EngRusActivity.java:37)
            at android.app.Activity.performCreate(Activity.java:4466)
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
            at android.app.ActivityThread.access$600(ActivityThread.java:123)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
            at android.os.Handler.dispatchMessage(Handler.java:99)
            at android.os.Looper.loop(Looper.java:137)
            at android.app.ActivityThread.main(ActivityThread.java:4424)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:511)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
            at dalvik.system.NativeStart.main(Native Method)
09-30 18:51:23.014    2298-2298/com.stetsenko.english02 E/class com.stetsenko.english02.ConectBD﹕ Ошибка! БД открыта
09-30 18:51:23.114    2298-2298/com.stetsenko.english02 E/class com.stetsenko.english02.ConectBD﹕ Ошибка копирования
09-30 18:51:23.114    2298-2298/com.stetsenko.english02 D/AndroidRuntime﹕ Shutting down VM
09-30 18:51:23.114    2298-2298/com.stetsenko.english02 W/dalvikvm﹕ threadid=1: thread exiting with uncaught exception (group=0x409bf1f8)
09-30 18:51:23.154    2298-2298/com.stetsenko.english02 E/AndroidRuntime﹕ FATAL EXCEPTION: main
    java.lang.Error: Ошибка копирования БД!
            at com.stetsenko.english02.ConectBD.createDataBase(ConectBD.java:49)
            at com.stetsenko.english02.ConectBD.openDataBase(ConectBD.java:100)
            at com.stetsenko.english02.ConectBD.<init>(ConectBD.java:36)
            at com.stetsenko.english02.EngRusActivity.onCreate(EngRusActivity.java:37)
            at android.app.Activity.performCreate(Activity.java:4466)
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
            at android.app.ActivityThread.access$600(ActivityThread.java:123)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
            at android.os.Handler.dispatchMessage(Handler.java:99)
            at android.os.Looper.loop(Looper.java:137)
            at android.app.ActivityThread.main(ActivityThread.java:4424)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:511)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
            at dalvik.system.NativeStart.main(Native Method)
09-30 18:51:23.204    2298-2303/com.stetsenko.english02 I/dalvikvm﹕ threadid=3: reacting to signal 3
09-30 18:51:23.274    2298-2303/com.stetsenko.english02 I/dalvikvm﹕ Wrote stack traces to '/data/anr/traces.txt'
09-30 18:51:23.684    2298-2303/com.stetsenko.english02 I/dalvikvm﹕ threadid=3: reacting to signal 3
09-30 18:51:23.714    2298-2303/com.stetsenko.english02 I/dalvikvm﹕ Wrote stack traces to '/data/anr/traces.txt'
09-30 18:51:24.054    2298-2303/com.stetsenko.english02 I/dalvikvm﹕ threadid=3: reacting to signal 3
09-30 18:51:24.084    2298-2303/com.stetsenko.english02 I/dalvikvm﹕ Wrote stack traces to '/data/anr/traces.txt'
09-30 18:51:24.644    2298-2303/com.stetsenko.english02 I/dalvikvm﹕ threadid=3: reacting to signal 3
09-30 18:51:24.684    2298-2303/com.stetsenko.english02 I/dalvikvm﹕ Wrote stack traces to '/data/anr/traces.txt'
09-30 18:51:25.154    2298-2303/com.stetsenko.english02 I/dalvikvm﹕ threadid=3: reacting to signal 3
09-30 18:51:25.194    2298-2303/com.stetsenko.english02 I/dalvikvm﹕ Wrote stack traces to '/data/anr/traces.txt'
09-30 18:51:25.454    2298-2298/com.stetsenko.english02 I/Process﹕ Sending signal. PID: 2298 SIG: 9

почему-то выводит
2298-2298/com.stetsenko.english02 E/class com.stetsenko.english02.ConectBD﹕ Ошибка! БД открыта
2298-2298/com.stetsenko.english02 E/class com.stetsenko.english02.ConectBD﹕ Ошибка копирования
Я отсоединился от БД
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
30.09.2015, 22:04
Привет! Вот еще темы с ответами:

Доступ к базе данных из разных активити - Программирование Android
В общем-то в теме и вопрос, как получить доступ к базе данных и разных активити? Есть класс работы с базой class DBHelper extends...

Создать несколько таблиц в базе данных - Программирование Android
Как создать 2 таблицы в бд?

Подключение эклипс к базе данных phpmyadmin - Программирование Android
пожалуйста дай пример как подключить android java project к phpmyadmin!!! либо помогите исправить мой код try { ...

AndroidStudio подключение к базе данных Oracle - Программирование Android
Доброго дня. Разрабатываю приложение с БД, база создана в Oracle Sql Developer. Нужна помощь, как через андроид студио можно...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru