|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
написал вин-приложение(си-шарп,студио 2008). приложение работает с БД *.mdb. в х64 вылетает след ошибка: "Microsoft.Jet.OLEDB.4.0" не зарегистрирован......". вручную зарегистрировать Microsoft.Jet.OLEDB.4.0 не каждый юзверь умеет +это неудобно. как быть? ... |
|||
:
Нравится:
Не нравится:
|
|||
19.11.2012, 23:54 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Использовать человеческие Embedded Database, например SQL CE 4.0 + EF. Акцесс я еще понимаю можно как-то юзать на сервере приложений (сайт, веб-сервис, wcf), но на клиента тащить это убожество уж уволь. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 00:06 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
МСУ,спасибо за совет, след раз буду знать.опыта не имею. в принципе у всех клиентов есть акцесс, не думал что так получится. а ща как быть с поставщиком OLE DB? ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 00:15 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
ZVER-10написал вин-приложение(си-шарп,студио 2008). приложение работает с БД *.mdb. в х64 вылетает след ошибка: "Microsoft.Jet.OLEDB.4.0" не зарегистрирован......". вручную зарегистрировать Microsoft.Jet.OLEDB.4.0 не каждый юзверь умеет +это неудобно. как быть?Правильно вылетает: "в природе" не существует Microsoft.Jet.OLEDB.4.0 для x64-систем... Соответственно, нужно использовать более "правильный" OLEDB-провайдер Microsoft.ACE.OLEDB.12.0, который идет в комплекте с 2010 Офисом. Проверьте версию соответствующих приложений у Ваших клиентов - возможно, ничего дополнительно даже не придется доустанавливать. "В крайнем случае" скачать отдельно Microsoft Access Database Engine 2010 Redistributable можно отсюда - "весит" что-то около 30 Мбайт. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 01:55 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
sphinx_mv, спс ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 06:54 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
ZVER-10МСУ,спасибо за совет, след раз буду знать.опыта не имею. в принципе у всех клиентов есть акцесс, не думал что так получится. а ща как быть с поставщиком OLE DB? Перепиши, пока не увяз по самые гланды. Поддерживать такие педали в дальнейшем будет затруднительно. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 09:30 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
ZVER-10написал вин-приложение(си-шарп,студио 2008). приложение работает с БД *.mdb. в х64 вылетает след ошибка: "Microsoft.Jet.OLEDB.4.0" не зарегистрирован......". вручную зарегистрировать Microsoft.Jet.OLEDB.4.0 не каждый юзверь умеет +это неудобно. как быть?Интересно, под какой ОС ты ее тестировал-то? Просто Msjet40.dll - это древняя штука... Я думал практически со всеми ОС должна идти... Как получить последнюю версию пакета обновлений для Microsoft Jet 4.0 Database Engine ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 14:02 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
МСУZVER-10МСУ,спасибо за совет, след раз буду знать.опыта не имею. в принципе у всех клиентов есть акцесс, не думал что так получится. а ща как быть с поставщиком OLE DB? Перепиши, пока не увяз по самые гланды. Поддерживать такие педали в дальнейшем будет затруднительно. мда, стоит подумать. постараюсь переписать. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 15:28 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Владимир САИнтересно, под какой ОС ты ее тестировал-то? под вин7 ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 15:30 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
ZVER-10Владимир САИнтересно, под какой ОС ты ее тестировал-то? под вин7Интересно, у меня win7 64-разрядная... И Msjet40.dll имеется в c:\Windows\System32\ .... ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 15:32 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Владимир САZVER-10пропущено... под вин7Интересно, у меня win7 64-разрядная... И Msjet40.dll имеется в c:\Windows\System32\ .... Причем тут наличие dll? Сам драйвер Microsoft.Jet.OLEDB.4.0 не работает на x64, нужен Microsoft.ACE.OLEDB.12.0. Причем битность AccessDatabaseEngine.exe нужно выбирать не исходя из биности оси, а исходя из битности офиса . Вообщем, саппортить эти лохмотья на толстых клиентах - самоубийство. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 15:42 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
МСУВладимир САпропущено... Интересно, у меня win7 64-разрядная... И Msjet40.dll имеется в c:\Windows\System32\ .... Причем тут наличие dll? Сам драйвер Microsoft.Jet.OLEDB.4.0 не работает на x64, нужен Microsoft.ACE.OLEDB.12.0. Причем битность AccessDatabaseEngine.exe нужно выбирать не исходя из биности оси, а исходя из битности офиса . Вообщем, саппортить эти лохмотья на толстых клиентах - самоубийство.Я конечно с таким гуру не могу спорить... Но у меня все работает... Код: 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. 36. 37. 38. 39.
Результат: Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15.
... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 15:51 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
МСУПричем битность AccessDatabaseEngine.exe нужно выбирать не исходя из биности оси, а исходя из битности офиса Не так, запамятовал. AccessDatabaseEngine нужно ставить на тачки, на которых не развернут офис. Помню были траблы при накате на тестовый сервер приложений - нужно было ставить AccessDatabaseEngine x64, а в ферме уже был развернут x32 офис, который пришлось сносить нах. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 15:52 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Владимир САНо у меня все работает... Скрин winmsd.exe в студию. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 15:56 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
МСУВладимир САНо у меня все работает... Скрин winmsd.exe в студию. msinfo32.exe ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 15:59 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
МСУВладимир САНо у меня все работает... Скрин winmsd.exe в студию. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 16:01 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Владимир СА Только что обратил внимание: dBASE IV. Мы про офис какбэ говорим, а именно о *.mdb. Попробуй. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 16:09 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
МСУВладимир СА Только что обратил внимание: dBASE IV. Мы про офис какбэ говорим, а именно о *.mdb. Попробуй.Блин... это я встрял как бы не в те ворота... Надо попробовать с mdb... Но завтра в командировку... Подготовлюсь.... Приеду - протестирую... ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 16:12 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Владимир САПриеду - протестирую... На каждую версию акцесса (до 2003 версии вкл.ючительно) - свой транслятор dll со определенным форматом (Jet 4.0, Jet 3.0, ...). http://support.microsoft.com/kb/303528 С 2007 версии акцесса и выше юзается уже другой драйвер - Microsoft.ACE.OLEDB.12.0. Ну а с DBF можно хоть через фокспрошный драйвер гонять данные :) P.S. Хотел в одно время в Прогноз устроиться, но Маяковка... Далеко сцуко :( ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 16:22 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
МСУВладимир САПриеду - протестирую... На каждую версию акцесса (до 2003 версии вкл.ючительно) - свой транслятор dll со определенным форматом (Jet 4.0, Jet 3.0, ...). http://support.microsoft.com/kb/303528 С 2007 версии акцесса и выше юзается уже другой драйвер - Microsoft.ACE.OLEDB.12.0. Ну а с DBF можно хоть через фокспрошный драйвер гонять данные :) P.S. Хотел в одно время в Прогноз устроиться, но Маяковка... Далеко сцуко :(бл*... Чисто согласен... Надо не бегло читать топик... На что и напоролся... Еще раз извиняюсь... Не в те сани... ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 16:26 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
МСУP.S. Хотел в одно время в Прогноз устроиться, но Маяковка... Далеко сцуко :(В Москве главный офис... ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 16:30 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
я тестировал на вин-7 где имеется 4-я версия. выдал ошибку. потом нашел вот эту ссылку и скомпилировал решение как х86 а не "Any CPU" и все работает нормально. только не знаю как будет в вин-8, нету под рукой вин-8 чтоб протестировать. ... |
|||
:
Нравится:
Не нравится:
|
|||
20.11.2012, 20:23 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
ZVER-10я тестировал на вин-7 где имеется 4-я версия. выдал ошибку. потом нашел вот эту ссылку и скомпилировал решение как х86 а не "Any CPU" и все работает нормально. только не знаю как будет в вин-8, нету под рукой вин-8 чтоб протестировать. У меня Visual Studio 2008 C# Express на русском языке. ОС - Виндовс 7. Я новичок сразу говорю. И мне задание работать именно с БД в Аксессе. И у меня не получается в настройках найти где менять с "ANY CPU" на х86. ... |
|||
:
Нравится:
Не нравится:
|
|||
02.05.2014, 14:39 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
dianad, в Solution Explorer правый клик на solution ->Configuration Properties -> Configuration Manager (кнопка в правом углу) -> Active solution platform -> <NEW> ... |
|||
:
Нравится:
Не нравится:
|
|||
02.05.2014, 21:23 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Была немного другая проблема. На отсутствие провайдера не ругалась программа. Просто при попытке открытия файла Excel из программы появлялось сообщение об ошибке открытия файла. Решил, что дело в провайдере и после того, как прочитал совет компилиции приложения под х86. Файлы стали нормально открываться и на Win7, хотя соединение происходит через Jet 4.0 Код: c# 1.
... |
|||
:
Нравится:
Не нравится:
|
|||
20.05.2014, 08:09 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Столкнулся с проблемой записи в DBF (нужно выгружать файл в заданном формате для сторонней конторы, а они его в свой 1С). Приложение ANY.CPU, терминальный сервер 64бита, офис 2007 (32). AccessDatabaseEngine_x64.exe не ставитс, т.к. офис 2007 и другого нет. DotNetDBF.dll - пишет очень криво А виндовые провайдеры не находятся, т.к. приложение 64, а провайдеры 32бита. Правильно ли я понял что это тупик? - Нет бесплатной сторонней либы под ANY.CPU способной писать в DBF. - Первый вариант, ставить офис 2010 х64. - Второй собирать проект под x86. Пробовал 4 варианта Код: 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. 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.
... |
|||
:
Нравится:
Не нравится:
|
|||
06.12.2015, 15:01 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
barrabasСтолкнулся с проблемой записи в DBF (нужно выгружать файл в заданном формате для сторонней конторы, а они его в свой 1С). Может легче договорится с той конторой об обмене данными через XML? ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 08:01 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Cat2, Ну у них разговор простой, у нас есть процедура загрузки, она работает, давайте нам в неё нужный файл. Не уверен что на их стороне есть разработчики вообще. ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 08:56 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
barrabas, Попробуйте драйвера для VPF (Visual Fox Pro). Обычно помогало. Так же вроде можно сделать таблицу в mdb и оттуда конвертировать в DBF ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 10:22 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Cat2barrabas, Попробуйте драйвера для VPF (Visual Fox Pro). Обычно помогало. Так же вроде можно сделать таблицу в mdb и оттуда конвертировать в DBFДа и вообще... поставить VFP 9.0 и на нем прогу сварганить...? Не подходит ? ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 10:27 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Cat2barrabas, Попробуйте драйвера для VPF (Visual Fox Pro). Обычно помогало. Так же вроде можно сделать таблицу в mdb и оттуда конвертировать в DBF да не, на foxpro теже 32 битные дрова и судя по форуму те-же пляски вокруг ODBC на x64. 64битное приложение не увидит 32битные дрова хоть убейся похоже. Думаю о варианте, написать маленькую 32битную консольную в которую на входящий поток будут слаться команды (типа вставь запись, открой соединения и т.д.). Эта программа будет лежать в папке приложения, когда надо, основное приложение запустит этот 32битный процесс, и будет слать туда инфу которую нужно сохранить в dbf, а потом закроет его (ну и само тоже чтоб закрывалось после 5 минут бездействия, если вдруг основное приложение рухнет, чтоб не засирался терминальный сервер). Просто собирать весь проект под х86 еще хуже вариант, у кучи людей стоят 64битные клиенты оракла (у тех что не через терминал работаю). а офиса нет 2010 ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 13:41 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
barrabasCat2barrabas, Попробуйте драйвера для VPF (Visual Fox Pro). Обычно помогало. Так же вроде можно сделать таблицу в mdb и оттуда конвертировать в DBF да не, на foxpro теже 32 битные дрова и судя по форуму те-же пляски вокруг ODBC на x64. 64битное приложение не увидит 32битные дрова хоть убейся похоже. Думаю о варианте, написать маленькую 32битную консольную в которую на входящий поток будут слаться команды (типа вставь запись, открой соединения и т.д.). Эта программа будет лежать в папке приложения, когда надо, основное приложение запустит этот 32битный процесс, и будет слать туда инфу которую нужно сохранить в dbf, а потом закроет его (ну и само тоже чтоб закрывалось после 5 минут бездействия, если вдруг основное приложение рухнет, чтоб не засирался терминальный сервер). Просто собирать весь проект под х86 еще хуже вариант, у кучи людей стоят 64битные клиенты оракла (у тех что не через терминал работаю). а офиса нет 2010 или написать прогу конвертер xml в нужный pdf, пользователь выбирает в основном приложении параметры для формирования, приложение лезет в базу, формирует xml, запускает x86-приложение-конвертер, ждет результата, удаляет xml. ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 13:49 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Cat2barrabasСтолкнулся с проблемой записи в DBF (нужно выгружать файл в заданном формате для сторонней конторы, а они его в свой 1С). Может легче договорится с той конторой об обмене данными через XML? легче писать dbf без использования кривых провайдеров и библиотек. ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 14:25 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Есть еще такая штука Не пользовался. Как понял читает/пишет DBF напрямую из/в файл без доп.драйверов ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 14:27 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
ИзопропилCat2пропущено... Может легче договорится с той конторой об обмене данными через XML? легче писать dbf без использования кривых провайдеров и библиотек. ну в принципе описание формата не сложное. но не хочется заниматься еще и этой хернёй. особенно в таком вопросе, нужно то просто выгрузить по кнопке в файлы. причем этот функционал работал, но сейчас идет загон юзеров в терминалку, она сама x64 т.к. 2008, а офис 32 т.к. 1С что-то тоже там формирует. Получается что отваливается функционал к которому возвращаться я не планировал вообще :( ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 15:17 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Dima TЕсть еще такая штука Не пользовался. Как понял читает/пишет DBF напрямую из/в файл без доп.драйверов спасибо, посмотрю ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 15:17 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
barrabasИзопропилпропущено... легче писать dbf без использования кривых провайдеров и библиотек. ну в принципе описание формата не сложное. но не хочется заниматься еще и этой хернёй. особенно в таком вопросе, нужно то просто выгрузить по кнопке в файлы. причем этот функционал работал, но сейчас идет загон юзеров в терминалку, она сама x64 т.к. 2008, а офис 32 т.к. 1С что-то тоже там формирует. Получается что отваливается функционал к которому возвращаться я не планировал вообще :(Дык, один раз сделать... и только кнопку жать... ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 15:19 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
barrabasDima TЕсть еще такая штука Не пользовался. Как понял читает/пишет DBF напрямую из/в файл без доп.драйверов спасибо, посмотрю Не пишет русскую кодировку. пробовал, и 1251, и 866. ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 18:02 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Владимир САbarrabasпропущено... ну в принципе описание формата не сложное. но не хочется заниматься еще и этой хернёй. особенно в таком вопросе, нужно то просто выгрузить по кнопке в файлы. причем этот функционал работал, но сейчас идет загон юзеров в терминалку, она сама x64 т.к. 2008, а офис 32 т.к. 1С что-то тоже там формирует. Получается что отваливается функционал к которому возвращаться я не планировал вообще :(Дык, один раз сделать... и только кнопку жать... Даже делать не пришлось. Нашел код, рабочий . Осталось поправить под себя. Хочу сделать все-таки типа построчного писателя. Загонять тысячи строк в datatable а потом только их писать, как-то не гуманно. Нужно датаридер построчно обслуживать. ... |
|||
:
Нравится:
Не нравится:
|
|||
07.12.2015, 18:07 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Можешь мою поделку потестить Код: 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. 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. 119. 120. 121. 122. 123. 124. 125. 126. 127. 128. 129. 130. 131. 132. 133. 134. 135. 136. 137. 138. 139. 140. 141. 142. 143. 144. 145. 146. 147. 148. 149. 150. 151. 152. 153. 154. 155. 156. 157. 158. 159. 160. 161. 162. 163. 164. 165. 166. 167. 168. 169. 170. 171. 172. 173. 174. 175. 176. 177. 178. 179. 180. 181. 182. 183. 184. 185. 186. 187. 188. 189. 190. 191. 192. 193. 194. 195. 196. 197. 198. 199. 200. 201. 202. 203. 204. 205. 206. 207. 208. 209. 210. 211. 212. 213. 214. 215. 216. 217. 218. 219. 220. 221. 222. 223. 224. 225. 226. 227. 228. 229. 230. 231. 232. 233. 234. 235. 236. 237. 238. 239. 240. 241. 242. 243. 244. 245. 246. 247. 248. 249. 250. 251. 252. 253. 254. 255. 256. 257. 258. 259. 260. 261. 262. 263. 264. 265. 266. 267. 268. 269. 270. 271. 272. 273. 274. 275. 276. 277. 278. 279. 280. 281. 282. 283. 284. 285. 286. 287. 288. 289. 290. 291. 292. 293. 294. 295. 296. 297. 298. 299. 300. 301. 302. 303. 304. 305. 306. 307. 308. 309. 310. 311. 312. 313. 314. 315. 316. 317. 318.
По моим тестам 1 млн. записей меньше секунды пишет. Память не расходует, сборки мусора минимум. Сделал для себя заготовку DBF писать с нуля. Тесты гонял - корректно пишет, результаты открываются в Visual FoxPro. В реальных проектах пока не использовал, т.к. пока только изучаю C#, до реального применения не все готово. ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 07:59 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Dima T, Спасибо. Тоже работает с 866. А Fast DBF посмотрел, там заголовок файла от 3й версии, там даже нет указания ID языкового драйвера. Ну так всегда бывает когда делают англоязычные товарищи. Помню в NPOI тоже слал баги связанные с десятичным разделителем в xml, они тупо не думают что бывают какие-то другие варианты, но там вроде оперативно ответили и дали патч. ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 09:49 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Dima T, Только что-то не понял с типами. Для double и single вроде как F должен быть. А N для decimal, для которого нет перегрузки метода Set ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 10:00 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
barrabasDima T, Только что-то не понял с типами. Для double и single вроде как F должен быть. А N для decimal, для которого нет перегрузки метода Set Для DBF всегда стандартным был тип NUMERIC, т.е. N. Тип F - это экзотика которая мало где встречается (лично мне не попадалось). Т.е. в итоге числовые типы всегда должны быть N Другой вопрос чем его представить внутри кода C#. Т.е. что давать на вход. С целыми понятно: Int32, а вот с дробными вопрос. Выбирал между decimal и double. Второй предпочтительнее оказался, т.к. этот тип процессор понимает, т.е. быстрее работает. Теоретически возможна проблема с точностью, но лично мне она не критична, т.к. double это точность 15 десятичных знаков - больше начинаются погрешности. Мне больше 10 никогда не надо, поэтому не критично если даже в расчетах поучаствуют. Если надо - могу добавить Set(Int32 col_num, Decimal value). По большому счету одно из двух: 1. в Set(Int32 col_num, Double value) заменить Double на Decimal 2. Привести Decimal к Double и Set(Int32 col_num, Double value) Надо только потестить как быстрее работать будет. Подозреваю что по варианту 2. ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 10:31 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Dima TbarrabasDima T, Только что-то не понял с типами. Для double и single вроде как F должен быть. А N для decimal, для которого нет перегрузки метода Set Для DBF всегда стандартным был тип NUMERIC, т.е. N. Тип F - это экзотика которая мало где встречается (лично мне не попадалось). Т.е. в итоге числовые типы всегда должны быть N Другой вопрос чем его представить внутри кода C#. Т.е. что давать на вход. С целыми понятно: Int32, а вот с дробными вопрос. Выбирал между decimal и double. Второй предпочтительнее оказался, т.к. этот тип процессор понимает, т.е. быстрее работает. Теоретически возможна проблема с точностью, но лично мне она не критична, т.к. double это точность 15 десятичных знаков - больше начинаются погрешности. Мне больше 10 никогда не надо, поэтому не критично если даже в расчетах поучаствуют. Если надо - могу добавить Set(Int32 col_num, Decimal value). По большому счету одно из двух: 1. в Set(Int32 col_num, Double value) заменить Double на Decimal 2. Привести Decimal к Double и Set(Int32 col_num, Double value) Надо только потестить как быстрее работать будет. Подозреваю что по варианту 2. Да можно и double, мне не принципиально для конкретной задачи. Вот чего не хватает реально, это DateTime?. Нужно пустую дату записать. Ее чем заменяют в dbf? 8 пробелов? ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 11:22 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
barrabasВот чего не хватает реально, это DateTime?. Нужно пустую дату записать. Ее чем заменяют в dbf? 8 пробелов? Да. 8 пробелов. У себя для записи пустой даты такой вариант предусмотрел Код: c# 1.
Или можно вообще не писать, т.к. по умолчанию пробелы. ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 11:50 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Dima TbarrabasВот чего не хватает реально, это DateTime?. Нужно пустую дату записать. Ее чем заменяют в dbf? 8 пробелов? Да. 8 пробелов. У себя для записи пустой даты такой вариант предусмотрел Код: c# 1.
Или можно вообще не писать, т.к. по умолчанию пробелы. А понял, просто пропустить Set, если null. ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 11:52 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Dima TbarrabasВот чего не хватает реально, это DateTime?. Нужно пустую дату записать. Ее чем заменяют в dbf? 8 пробелов? Да. 8 пробелов. У себя для записи пустой даты такой вариант предусмотрел Код: c# 1.
Или можно вообще не писать, т.к. по умолчанию пробелы. не обратил внимание на if (value.Year > 1) :) ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 11:53 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
barrabasА понял, просто пропустить Set, если null. Да. В DBF можно любые поля вообще не писать, т.е. оставлять пробелы. Тогда загрузчик будет его считать пустым и подставлять для чисел 0, строк "" и т.д., но это не null. null по другому делается. ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 12:07 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Dima T, В конце ты не ставишь EOF-маркер = 1A ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 14:16 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
barrabasDima T, В конце ты не ставишь EOF-маркер = 1A Не заметил. Похоже его никто не проверяет. В FoxPro открываются, в экселе тоже. У тебя где-то не прочиталось? Добавил. Добавь в коде выделенную строчку Код: 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.
... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 14:37 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Dima TbarrabasDima T, В конце ты не ставишь EOF-маркер = 1A Не заметил. Похоже его никто не проверяет. В FoxPro открываются, в экселе тоже. У тебя где-то не прочиталось? Добавил. Добавь в коде выделенную строчку Код: 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.
Просто начал сравнивать 2 файла в хексе и заметил, полез в доку по формату, там написано что должен быть маркер. ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 14:45 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Ну всё, полное соответствие с файлами созданными через тормозной OLEDB:) Спасибо, Dima T. ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 14:53 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Я по этой описаловке делал. Там нет его. Смотрел в FoxPro - его тоже нет, если использовать родные DBF, но если из фокса выгрузить в формат dBASE IV - то есть. ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 14:53 |
|
Microsoft.Jet.OLEDB.4.0" не зарегистрирован
|
|||
---|---|---|---|
#18+
Dima TЯ по этой описаловке делал. Там нет его. Смотрел в FoxPro - его тоже нет, если использовать родные DBF, но если из фокса выгрузить в формат dBASE IV - то есть. Я тут смотрел ... |
|||
:
Нравится:
Не нравится:
|
|||
08.12.2015, 14:56 |
|
|
start [/forum/topic.php?all=1&fid=20&tid=1400994]: |
0ms |
get settings: |
7ms |
get forum list: |
13ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
37ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
74ms |
get tp. blocked users: |
1ms |
others: | 12ms |
total: | 166ms |
0 / 0 |