Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
2 / 2 / 5
Регистрация: 28.06.2015
Сообщений: 81

Прочитать данные из нужной БД

21.06.2016, 18:16. Показов 649. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, у меня возник вопрос по поводу чтения данных из нужной БД. В моем приложении пользователь нажимает в ResyclerView на элемент и вызывается активность с подробной информацией об этом элементе. В интент кладется номер нажатой пользователем позиции на ResyclerView и активность с подробной информацией понимает, что ей нужно вывести. Но как сделать так чтобы вызывалась информация из нужной БД, к примеру если пользователь нажмет на первый пункт - вызовется информация из первой БД, для второго пункта из второй БД.
Вот класс базы данных:
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
public class MyDataBase {
 
    private DBOpenHelper dbOpenHelper;
    private SQLiteDatabase database;
 
    private static final String DB_NAME = "AutoRate";
    private static final String TABLE_NAME = "AUTOCOLOR";
    private static final String SECOND_TABLE_NAME = "AUTORATE";
 
    public static final String NAME = "NAME";
    public static final String DESCRIPTION = "DESCRIPTION";
    public static final String PRICE = "PRICE";
 
 
    private static final int DB_VERSION = 1;
 
    public MyDataBase(Context context) {
        dbOpenHelper = new DBOpenHelper(context);
    }
    public String getDataBaseName(){
        return TABLE_NAME;
    }
 
    public Cursor getAllItems() {
        database = dbOpenHelper.getReadableDatabase();
        return database.query(TABLE_NAME, null, null, null, null, null, null);
    }
 
    public void close() {
        if (dbOpenHelper != null) dbOpenHelper.close();
        if (database != null) database.close();
    }
    public class DBOpenHelper extends SQLiteOpenHelper {
 
 
 
        public DBOpenHelper(Context context) {
            super(context, DB_NAME, null, DB_VERSION);
        }
 
        @Override
        public void onCreate(SQLiteDatabase db) {
            db.execSQL("CREATE TABLE " + TABLE_NAME + " (_id INTEGER PRIMARY KEY AUTOINCREMENT, "
                    + NAME + " TEXT, "
                    + DESCRIPTION + " TEXT, "
                    + PRICE + " INTEGER) ;");
            insertService(db, "AUTOCOLOR", "Шиномонтаж", "Замена четырех колес", 4000);
            insertService(db, "AUTOCOLOR", "Кузовные работы", "Замена чего то там", 10000);
            insertService(db, "AUTOCOLOR", "Диагностика", "Продиагностировать чего-нибудь", 3000);
 
 
            db.execSQL("CREATE TABLE " + SECOND_TABLE_NAME + " (_id INTEGER PRIMARY KEY AUTOINCREMENT, "
                    + NAME + " TEXT, "
                    + DESCRIPTION + " TEXT, "
                    + PRICE + " INTEGER) ;");
            insertService(db, "AUTORATE", "Шиномонтаж", "Замена четырех колес", 5000);
            insertService(db, "AUTORATE", "Кузовные работы", "Замена чего то там", 12000);
            insertService(db, "AUTORATE", "Диагностика", "Продиагностировать чего-нибудь", 4000);
 
 
        }
        
 
        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
 
        }
 
        private void insertService(SQLiteDatabase db, String currentDataBaseName, String name, String description, int price) {
            ContentValues contentValues = new ContentValues();
            contentValues.put(NAME, name);
            contentValues.put(DESCRIPTION, description);
            contentValues.put(PRICE , price);
            db.insert(currentDataBaseName, null, contentValues);
        }
    }
}
Место в другом классе, где из интента берется номер нажатой позиции и инициализируется БД.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
 @Override
    protected void onCreate(Bundle savedInstanceState){
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_auto_service_detail);
        Bundle bundle= getIntent().getExtras();
        if(bundle != null){
            Object o = bundle.get(EXTRA_SERVICE_NO);
            autoServiceNo = (Integer.parseInt(String.valueOf(o)));
        }
        dataBase = new MyDataBase(this);
        Cursor cursor = dataBase.getAllItems();
 
        String[]from = new String[]{MyDataBase.NAME,MyDataBase.DESCRIPTION,MyDataBase.PRICE};
        int[] to = new int[]{R.id.tvName, R.id.tvDescription, R.id.tvPrise};
 
 
        cursorAdapter = new SimpleCursorAdapter(this, R.layout.item, cursor, from, to,0);
        listView = (ListView)findViewById(R.id.listViewPrise);
        listView.setAdapter(cursorAdapter);
Как мне используя
Java
1
2
3
4
5
Bundle bundle= getIntent().getExtras();
        if(bundle != null){
            Object o = bundle.get(EXTRA_SERVICE_NO);
            autoServiceNo = (Integer.parseInt(String.valueOf(o)));
        }
прочитать данные из нужной БД?

Добавлено через 43 минуты
Если я в метод
Java
1
2
3
4
public Cursor getAllItems() {
        database = dbOpenHelper.getReadableDatabase();
        return database.query(TABLE_NAME, null, null, null, null, null, null);
    }
передам имя таблицы, вытащив его из интента:
Java
1
tableName = AutoServiceInfo.autoServices[autoServiceNo].getName();
и передав имя текущей таблицы в метод
Java
1
2
3
4
public Cursor getAllItems(String tableName) {
        database = dbOpenHelper.getReadableDatabase();
        return database.query(tableName, null, null, null, null, null, null);
    }
, то для первой таблицы все работает нормально, а когда я пытаюсь нажать на ResyclerView на второй элемент, то приложение крашется и пишет что Caused by: android.database.sqlite.SQLiteException: no such table: AUTORATE (code 1): , while compiling: SELECT * FROM AUTORATE.

Добавлено через 2 часа 47 минут
Если кому будет интересна эта новость, то решение ошибки - удалить приложение с устройства и поставить заного, так как я не проапгрейдил версию базы данных. ХЕХЕХ. и телефон при первом запуске запомнил первую версию БД с одной таблицой.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.06.2016, 18:16
Ответы с готовыми решениями:

Прочитать файл в нужной кодировке
Здравствуйте уважаемые форумчане подскажите пожалуйста. Как перевести delphi строку в C# строку. Строка записана в файл я ей считываю с...

Прочитать текст из файла в текстовое поле в нужной кодировке
Всем привет! Есть файл (во вложение) Пытаюсь прочитать из него текст: TextBox1.Text =...

Как прочитать данные из ячейки, и если она пуста добавить данные
Привет всем. У меня есть вот такой код: <?php $arrqq = array($row->id); foreach($arrqq as $d => $s) { $imagetext =...

1
 Аватар для Dark-VIN
1 / 1 / 0
Регистрация: 16.01.2013
Сообщений: 82
25.06.2016, 10:31
Можно, конечно, создать два разных класса и в них создавать свою БД, но лучше всего создать одну БД и расформировать все по таблицам.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.06.2016, 10:31
Помогаю со студенческими работами здесь

Записать данные в файл в нужной папке
<? $characters='0123456789abcdefghijklmnopqrstuvwxyz'; $pass_characters = str_split($characters); $pass_length = "6"; ...

Как вывести данные из нужной ячейки таблицы БД
Есть база данных в mysql Database: basakv в ней есть таблица cms_build. в ней есть ячейки $id; $number; $price; $status; ...

Как записать данные в файл в нужной кодировке
В общем как не пытаюсь выгрузить данные в csv из List<string> мучаюсь с кодировкой. Через excel выходят крякозябры. Через notepad++...

Как вывести данные из нужной ячейки access в TextBox?
Здравствуйте! Как обновить из TextBox в access разобрался! Sub UpdateStr(ByVal KeyValue As Integer) SqlCom = New...

Как перенести данные из dbgrid нужной строки в tedit
Есть таблица dbgrid данные входят с бд msaccess используя компоненты ADOConnection DataSource ADOQuery id имя фамилия ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru