С Новым годом! Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.52/21: Рейтинг темы: голосов - 21, средняя оценка - 4.52
0 / 0 / 0
Регистрация: 28.02.2018
Сообщений: 4

Программа не подключается к БД SQLite на другом устройстве

28.02.2018, 13:53. Показов 4602. Ответов 7

Студворк — интернет-сервис помощи студентам
Всем привет!
Помогите плз! Написал программу на c# + sqlite. Написал на ноутбуке, на нем все работает. Переношу на домашний комп не работает. Пишет что не может открыть БД, потому что не может найти часть пути к БД. Ну оно и логично, путь к БД различается на разных устройствах. Но весь прикол в том, что если я в программе на 2м устройстве(домашнем компе) меняю строку подключения, на правильную для этого устройства (т.е. туда куда и положил фактически сам файл БД на этом устройстве), то все равно приложение подает с той же ошибкой.
Самое интересное, что в деталях ошибки, в InnerExeption пишет старый путь с первого устройства, не смотря на то, что строку подключения я изменил.

Вообще мне нужно, чтобы БД открывалась на любом устройстве не зависимо от того, куда положат папку с приложением и БД.
Перерыл Интернет нашел как это делается:
1) Нужно положить файл БД в папку с exe приложения
2) В строке подключения писать "Data Source=DBName.db; Version=3"

и по идее все должно работать вне зависимости от пути к файлу.
Все сделал также, закинул файл sqlite dll в папку с exe.
Не работает. Показывает всё ту же ошибку и ругается на старый путь от первого устройства.


В связи с чем вопросы:
1) Может где-то прописывается в глубоких настройках строка подключения к БД и потому все равно меняй, не меняй строку подключения, программа будет смотреть на первичный путь к БД? Если да, то как исправить???
2) Как все-таки реализовать подключение к БД вне зависимости от устройства, т.е. чтобы программа смотрела по умолчанию на БД в каталоге с программой?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.02.2018, 13:53
Ответы с готовыми решениями:

программа подключается к базе (Firebird, SQLite) только на компе с Microsoft Visual C#
Подскажите, пожалуйста, как разобраться. Программа подключается к базе (Firebird, SQLite) только на компе с Microsoft Visual C#, на...

Где хранится файл базы данных SQLite на устройстве?
Здравствуйте друзья! Где храниться файл базы данных SQLite на устройстве или может этот файл создается автоматически при загрузке...

Роутер asus rt-n12vp работает подключается к интернету ,но страницы не на одном устройстве не открываются
Купил роутер asus подключил к компьютеру,настроил подключение к интернету показывает активным,подключаюсь к вайфаю с любого устройства все...

7
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
28.02.2018, 14:19
Цитата Сообщение от CKOT666 Посмотреть сообщение
закинул файл sqlite dll в папку с exe
Цитата Сообщение от CKOT666 Посмотреть сообщение
Data Source=DBName.db
Ничего не улавливаете?
При чем тут библиотека для работы с БД и сам файл БД?
0
0 / 0 / 0
Регистрация: 28.02.2018
Сообщений: 4
28.02.2018, 14:34  [ТС]
Прошу прощения, наверно не понятно выразился:
В папке с exe лежит и sqlite dll и файл базы данных (HR.db).
0
0 / 0 / 0
Регистрация: 28.02.2018
Сообщений: 4
28.02.2018, 14:45  [ТС]
Еще забыл уточнить, что ошибка появляется при заполнении combobox'a значениями из таблицы БД.

C#
1
this.employeesTableAdapter.Fill(this.hR_db.Employees);
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18245 / 14165 / 5366
Регистрация: 17.03.2014
Сообщений: 28,848
Записей в блоге: 1
28.02.2018, 14:59
CKOT666, судя по скриншоту (на котором непросто что-то рассмотреть) строка соединения у тебя в одном методе, а код с исклюением в другом. То есть ты видимо меняешь не ту строку подключения. Посмотри в файле конфигурации.
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
28.02.2018, 15:21
Цитата Сообщение от CKOT666 Посмотреть сообщение
this.employeesTableAdapter.Fill(this.hR_ db.Employees);
А TableAdapter создавался мастером на старом компе. И строка соединения у него старая.
0
0 / 0 / 0
Регистрация: 28.02.2018
Сообщений: 4
28.02.2018, 18:35  [ТС]
Да, все правильно, в файле конфигурации был старый путь. Поменял, теперь появляется ошибка

System.BadImageFormatException: "Была сделана попытка загрузить программу, имеющую неверный формат. (Исключение из HRESULT: 0x8007000B)"

При выполнении:
C#
1
 SQLiteConnection connection = new SQLiteConnection(connectionString);
Если я правильно понимаю, то мне теперь не нужно каждый раз передавать строку подключения, чтобы открыть соединение.
Но как тогда открыть соединение со строкой, которая прописана в файле конфигурации, чтобы, например, потом выполнить запрос к БД? пример ниже

C#
1
2
3
4
5
6
7
8
9
10
11
12
string connectionString = "Data Source=HR.db; Version=3;";
            SQLiteConnection connection = new SQLiteConnection(connectionString);
            
            connection.Open();
 
            string query = "Select count(id) from employees";
            SQLiteCommand command = new SQLiteCommand(query, connection);
 
            int QuantityEmployees = Convert.ToInt32(command.ExecuteScalar());
 
            connection.Close();
            return QuantityEmployees;
Добавлено через 55 минут
Победил.
вот по этой теме:
Была сделана попытка загрузить программу, имеющую неверный формат. (Исключение из HRESULT: 0x8007000B)
только наоборот х64.

Теперь не хочет распознавать строку, как datetime, которую раньше распознавал без проблем.
Пойду вскроюсь.Добавлено через 1 час 17 минут
А не, походу какой-то временный глюк.
Все работает, всем спасибо!
0
Эксперт .NET
 Аватар для insite2012
5548 / 4311 / 1218
Регистрация: 12.10.2013
Сообщений: 12,371
Записей в блоге: 2
03.03.2018, 19:37
Цитата Сообщение от CKOT666 Посмотреть сообщение
Как все-таки реализовать подключение к БД вне зависимости от устройства, т.е. чтобы программа смотрела по умолчанию на БД в каталоге с программой?
string pathToDb=string.Format("Data Source={0}", Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "database.db"));
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.03.2018, 19:37
Помогаю со студенческими работами здесь

Какие данные необходимо перенести с телефона чтобы приложение заработало на другом устройстве
привет есть программа андройд какие папки с данными необходимо перенести на другой телефон чтобы перенеслись все достижения в данной...

Перемещение существующей БД в SQLite на другом приложении
Существует некоторая БД, которая программировалась в MSQL Manager, в Visual Studio я создал проект и скачал на неё SQLite, каким образом...

Как узнать на каком устройстве запущена программа
Как узнать на каком устройстве запущена программа, то есть например iPhone 4 или iPad 2?

Xamarin программа на развертывается на физическом Android устройстве
Не пойму в чем дело, до перестановки ОС запускать получалось, а сейчас нет. Телефон лежит и не реагирует. Раньше сразу выдавало установку...

Программа, которая выводит в окно применения информацию об устройстве и метрике
Написать, с использованием функций API, программу, которая выводит в окно применения информацию, получаемую из контекста, об устройстве и...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru