0 / 0 / 0
Регистрация: 10.05.2012
Сообщений: 34
1

Не читается DBF файл из корневой директории диска

10.06.2013, 11:32. Показов 1460. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Всем привет, следующая проблема, DBF файл не читается только из корневой директории диска, то есть из D:\dbf.dbf не читается, а вот из D:\folder\dbf.dbf уже читается
Подключение происходит нормально, а вот когда пытаюсь применить метод pRec = pConn->Execute(query, NULL, 0);
файл не находит(
Обращаю внимание еще раз: не находит только в корневой директории, у кого-нибудь есть какие-нибудь соображения по этому поводу?


C++
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
 ADOclass::ADOclass (const char* path)
{
  query = "SELECT * FROM " + static_cast<_bstr_t>(path); // создаем запрос в зависимости от путя
 
  /* В ЭТОМ БЛОКЕ ПРОИСХОДИТ СБОРКА СТРОКИ СОЕДИНЕНИЯ В ЗАВИСИМОСТИ ОТ ДИСКА НА КОТОРОМ ЛЕЖИТ DBF ФАЙЛ */
  char localDisk[2];
  localDisk[0] = path[0];
  localDisk[1] = '\0';
  _bstr_t strcnn = "Driver={Microsoft dBASE Driver (*.dbf)};DriverID=277;Dbq=" + static_cast<_bstr_t>(localDisk) + ":\\;";
  /* КОНЕЦ БЛОКА */
  //_bstr_t strcnn = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=D:; Extended Properties=""DBASE IV;";
  HRESULT hr;
  CoInitialize(NULL);  // инициализирую СОМ объект
 
  //создаю объект connection для предоставления соединения с источником данных и инициализирую его
  pConn.CreateInstance("ADODB.Connection");
  //создаю соединение с файлом
  hr = pConn->Open(strcnn, "", "", adConnectUnspecified);
  if (FAILED (hr))
  {
    throw (_com_error (pConn));
  }
  /*создаю объект Recordset, предназначенный для хранения данных, возвращенных из источника данных,
    и инициализирую его*/ 
  pRec.CreateInstance("ADODB.Recordset");
  
  //задаем тип курсора - клиентский (необходимо выполнить перед созданием связи)
  pRec->CursorLocation = adUseClient;
  pRec->CursorType = adOpenForwardOnly;
}
 
void ADOclass::Execute()
{
  pRec = pConn->Execute(query, NULL, 0);
}
Буду рад любой помощи, замечу так же, что использовал следующий драйвер _bstr_t strcnn = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=D:; Extended Properties=""DBASE IV;"; и та же ошибка, так что думаю дело не в драйвере
Пытался открыть вот этим методом //pRec->Open(query, _variant_t((IDispatch*)pConn,true),adOpenForwardOnly, adLockReadOnly, adCmdFile); но он почему-то вообще файл не находит, так же как и этот
pRec->Open(query, pConn.GetInterfacePtr() ,adOpenForwardOnly, adLockReadOnly, adCmdFile);
query у меня вида SELECT * FROM <путь и имя файла>, например SELECT * FROM D:\folder\dbf.dbf
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
10.06.2013, 11:32
Ответы с готовыми решениями:

Не читается файл с жесткого диска
У меня винчестер разбит на 3 раздела: 2 по 250 гб и 3-й размером 500 гб. На последнем и находится...

Ошибка нахождения корневой директории
package semestralka_baza_mangi; import java.io.BufferedReader; import...

Список файлов в корневой директории
Пустой список /storage/sdcard0 File root; File curFolder; ... root = new...

Включение файла из корневой директории
Всем привет. Вопрос простой: подключаю файл: require_once(&quot;db_login.php&quot;);//файл с...

3
Модератор
3401 / 2172 / 353
Регистрация: 13.01.2012
Сообщений: 8,413
10.06.2013, 12:19 2
вместо Data Source=D: попробуйте все же наверное более правильное Data Source=D:\
0
0 / 0 / 0
Регистрация: 10.05.2012
Сообщений: 34
13.06.2013, 10:36  [ТС] 3
не, все равно не читает, но было найдено другое решение, если кому будет интересно то вот оно:
получить путь до папки TEMP, туда скопировать любой файлик, а уже оттуда читать
путь до TEMP можно получить воспользовавшись функцией GetEnvironmentVariable ("TEMP", buf, bufsize)
0
Модератор
3401 / 2172 / 353
Регистрация: 13.01.2012
Сообщений: 8,413
13.06.2013, 21:46 4
Цитата Сообщение от monnzz Посмотреть сообщение
другое решение
как вариант - что то с правами NTFS
0
13.06.2013, 21:46
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.06.2013, 21:46
Помогаю со студенческими работами здесь

Установка корневой директории в QFileSystemModel
Столкнулся с непонятной для меня проблемой. При попытке установить коневую директорию для модели...

Сдвиг текста (отсечение корневой директории)
Необходимо в cmd создать условие, чтобы он находил слово Vat\, то выводилось бы со сдвигом вправо...

Получение корневой директории и логических дисков через скрипт
Здравствуйте. Меня интересует следующий вопрос - как с помощью скрипта узнать логические...

Кривое отображение файлов в папке(вне корневой директории)
Приветствую всех!!!Проблема следующая.Файлы находящиеся в корневом каталоге отображаются...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru