Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.97/30: Рейтинг темы: голосов - 30, средняя оценка - 4.97
1 / 1 / 0
Регистрация: 23.09.2015
Сообщений: 43

Работа с файлом базы .dbf

15.12.2015, 14:07. Показов 6596. Ответов 24
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите, как можно поднять сервер по файлу БД? Требуется доставать оттуда определённые данные по требованию.
Буду рад, если подскажете насколько это ресурсоёмко и есть ли альтернативы.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.12.2015, 14:07
Ответы с готовыми решениями:

Работа с DBF файлом
Всем привет есть код: public DataTable GetQuerySelect(string strConnect, string strFileName) { var fileConnect =...

Работа с dbf в C# - вывести содержимое dbf в dataGridView
Необходимо вывести содержимое dbf в dataGridView, подскажите как сделать.... Заранее спасибо....

Помогите с файлом *.dbf
Подскажите, можно ли реализовать такую задачу?: Есть файл test.dbf, в нем поля для заполнения (name, address, telephone, и т.п.). Надо...

24
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
15.12.2015, 14:50
Цитата Сообщение от Bill77 Посмотреть сообщение
как можно поднять сервер по файлу БД
Во-первых, расширение файла нонче ничего не означает. Например, файлы БД Oracle тоже могут иметь расширение dbf.
Во-вторых, если все-таки имеется ввиду файл формата dBase, то для него никакой сервер не требуется, работа с файлом осуществляет клиентская программа. Через то же ADO. Не говоря уж о том, что под dbf-файлы есть драйверы ODBC.
1
1 / 1 / 0
Регистрация: 23.09.2015
Сообщений: 43
15.12.2015, 15:03  [ТС]
Тогда уточните, пожалуйста, что за драйвера, что за проги и как ими пользоваться?
От какой базы файлы не знаю, поэтому хочу узнать все варианты работы. Однако предпочтительнее не пользоваться сторонними прогами.
Прямое подключение типа
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
            string FilePath = "D:\\TT\\ByteEnterprise2\";
            string DBF_FileName = "ATTACHMT.dbf";
            OdbcConnection obdcconn = new System.Data.Odbc.OdbcConnection();
            obdcconn.ConnectionString = "Driver={Microsoft dBase Driver (*.dbf)};SourceType=DBF;SourceDB=" + FilePath + ";Exclusive=No; NULL=NO;DELETED=NO;BACKGROUNDFETCH=NO;";
            //connetionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + putFileName + ";";
            obdcconn.Open();
            OdbcCommand oCmd = obdcconn.CreateCommand();
            oCmd.CommandText = "SELECT * FROM " + FilePath + DBF_FileName;
 
            /*Load data to table*/
 
            DataTable dt1 = new DataTable();
            dt1.Load(oCmd.ExecuteReader());
            obdcconn.Close();
Выдаёт ошибку о неверном типе базы на строке "dt1.Load(oCmd.ExecuteReader());".
Поэтому я подумал насчёт поднятия сервера. Подскажите, где ошибки.
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
15.12.2015, 15:14
Цитата Сообщение от Bill77 Посмотреть сообщение
От какой базы файлы не знаю
Тогда для начала нужно выяснить, что за БД, иначе будет "метод научного тыка". В Инете есть куча программ для чтения/редактирования "истинного" dbf. Не говоря уж о том, что всеми любимый Excel тоже может его читать.
1
1 / 1 / 0
Регистрация: 23.09.2015
Сообщений: 43
15.12.2015, 15:21  [ТС]
Открыть я её могу без проблем, хотя в экселе кодировка ломается. Выяснил, что бд скорее всего SQL Server.
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
15.12.2015, 17:01
Цитата Сообщение от Bill77 Посмотреть сообщение
oCmd.CommandText = "SELECT * FROM " + FilePath + DBF_FileName;
Нужно указывать только имя файла. Без FilePath.
1
1 / 1 / 0
Регистрация: 23.09.2015
Сообщений: 43
16.12.2015, 08:09  [ТС]
Не вижу смысла, как тогда будет определяться откуда файл брать если я путь до него не укажу?
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
16.12.2015, 10:11
Цитата Сообщение от Bill77 Посмотреть сообщение
Не вижу смысла, как тогда будет определяться откуда файл брать если я путь до него не укажу?
Путь указывается в строке подключения.

http://www.connectionstrings.com/dbf-foxpro/
1
1 / 1 / 0
Регистрация: 23.09.2015
Сообщений: 43
16.12.2015, 14:17  [ТС]
Цитата Сообщение от Igr_ok Посмотреть сообщение
Путь указывается в строке подключения.
http://www.connectionstrings.com/dbf-foxpro/
Я правильно понимаю надо писать как-то так?
C#
1
2
string driver = "Driver={Microsoft dBase Driver (*.dbf)};SourceType=DBF;SourceDB=" + FilePath + ";Exclusive=No; NULL=NO;DELETED=NO;BACKGROUNDFETCH=NO;";
            obdcconn.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + FilePath + ";Extended Properties=dBASE IV;User ID=Admin;Password=;" + driver;
Тогда при попытке прочитать базу возникает ошибка "ERROR [42S02] [Microsoft][Драйвер ODBC dBase] Объект 'ATTACHMT.dbf' не найден ядром базы данных Microsoft Jet. Проверьте существование объекта и правильность имени и пути.".
Как я понимаю ошибся с типом базы? Или в чём ошибка?
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
16.12.2015, 17:21
Цитата Сообщение от Bill77 Посмотреть сообщение
Я правильно понимаю надо писать как-то так?
Нет.
C#
1
string myConnectionString ="Driver={Microsoft dBase Driver (*.dbf)};DBQ="+FilePath ;
1
1 / 1 / 0
Регистрация: 23.09.2015
Сообщений: 43
17.12.2015, 09:21  [ТС]
В таком случае возникает другая ошибка
"ERROR [HY000] [Microsoft][Драйвер ODBC dBase] Внешняя таблица не имеет предполагаемый формат."
Как быть с ней?
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
17.12.2015, 09:43
Bill77, можете показать свой файл? Нужно убедиться, что это действительно dbf. Только заархивируйте его.
1
1 / 1 / 0
Регистрация: 23.09.2015
Сообщений: 43
17.12.2015, 10:13  [ТС]
Добавил файл.
Вложения
Тип файла: 7z ATTACHMT1.7z (3.2 Кб, 9 просмотров)
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
17.12.2015, 12:45
Это dbf, но проблемы с кодировкой есть. Детальнее смогу сказать вечером, когда доберусь к домашнему компу.
Миниатюры
Работа с файлом базы .dbf  
1
1 / 1 / 0
Регистрация: 23.09.2015
Сообщений: 43
17.12.2015, 12:46  [ТС]
Спасибо, буду ждать. Возможно стоит сказать что я тут выяснил. Первоначально файл был с расширением .tti, но его пересохранили в .dbf.
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
17.12.2015, 16:08
Цитата Сообщение от Igr_ok Посмотреть сообщение
Это dbf, но проблемы с кодировкой есть
У меня в программе Universal Database Viewer просматривается без проблем с кодировкой. Правда в пункте о языке показывает Without Code Page. Такое впечатление, что формат dBaseIII (тогда еще кодировку в заголовок файла не писали) и кодировка DOS. Тем более, что когда я из Excel скопировал русскоязычное поле в редактор (AkelPad) и сказал "Сохранить как DOS-866", то в файл сохранилась корректная надпись.
1
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
17.12.2015, 21:17
Файл открывается DBFNavigator. А если его еще и сохранить, то читается драйвером dbf без ошибок. Но с кодировкой ничего не получилось.
Цитата Сообщение от Grossmeister Посмотреть сообщение
Такое впечатление, что формат dBaseIII (тогда еще кодировку в заголовок файла не писали) и кодировка DOS.
Сохранил как dBaseIV и в 16-тиричном редакторе пытался прописать стандартные кодовые страницы, но ни одна не подошла.

Попробуйте получить файл в формате dBaseIV или xls/xlsx.
1
1 / 1 / 0
Регистрация: 23.09.2015
Сообщений: 43
18.12.2015, 11:46  [ТС]
А подскажите, сработает ли данное дополнение для чтения файла?
Если это может помочь то объясните пожалуйста как установить его.
0
1 / 1 / 0
Регистрация: 23.09.2015
Сообщений: 43
24.12.2015, 15:09  [ТС]
Цитата Сообщение от Igr_ok Посмотреть сообщение
Файл открывается DBFNavigator. А если его еще и сохранить, то читается драйвером dbf без ошибок. Но с кодировкой ничего не получилось.
У вас получилось прочитать этот файл? У меня есть шансы считать этот файл?
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
28.12.2015, 10:51
Цитата Сообщение от Bill77 Посмотреть сообщение
У меня есть шансы считать этот файл?
Даже если получится прочитать файл, я не вижу способа "победить" кривую кодировку. Поэтому и советовал получить от того, кто его вам прислал
Цитата Сообщение от Igr_ok Посмотреть сообщение
в формате dBaseIV или xls/xlsx.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.12.2015, 10:51
Помогаю со студенческими работами здесь

GUI Работа с текстовым файлом, лог файлом не мешая системе
Хочу написать прогу которая будет по таймеру искать в тхт - лог файле сообщение об ошибке. Например Error: 100 Qt C++ gui изучаю недавно...

Создание dbf базы
Доброго времени суток. Мне нужно создать файл dbf и в него записать определенные данные. Есть такой код string connString =...

Объем базы Dbf
Господа программисты. А кого-нибудь есть данные по следующему сабжу: -сколько весит каждый новый документ -сколько весит каждый...

конвертация базы .dbf
Добрый день! Ситуация такая: есть папочка на панели оператора, куда каждый день, раз в сутки генерируется отчет программой визуализации....

Создание базы dbf в лазарус
Скажите пожалуйста, как программно указать путь, куда необходимо сохранить базу без возможности выбора пользователем этого пути. И попутно...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru