|
0 / 0 / 0
Регистрация: 20.09.2013
Сообщений: 50
|
|
База данных ADO09.09.2016, 05:57. Показов 1614. Ответов 21
Метки нет (Все метки)
Всем привет. В общем дело такое, я через ADO загружаю *dbf таблицу в ДЕЛФИ. И я эту таблицу с помошью ADOTable в Access выгружаю/экспортирую. У меня все получается, только если мне известны наименование столбцов *dbf файла, и я даю такие же имена в таблицу Access. А мне нужно сделать так, что бы не знаю параметров таблицы, выгружать ее в Access. То есть например, допустим скинули мне *dbf файл, что бы я его в Access открыл, я просто загрузил в ДЕЛФИ и сразу же выгрузил в Access. Если честно я понятия не имею как это делается, подскажите форумчане. За ранее спасибо.
0
|
|
| 09.09.2016, 05:57 | |
|
Ответы с готовыми решениями:
21
ADO база на access, как распечатать, сохранить, добавить и т.д База данных, Delphi и ADO
|
|
0 / 0 / 0
Регистрация: 20.09.2013
Сообщений: 50
|
|
| 09.09.2016, 09:00 [ТС] | |
|
Точнее не загружаю, а открываю через Ado как обычную таблицу в гриде. Да, я именно так и сохраняю через fieldbyname. Я мне нужно обойтись без этого, то есть не давай имена столбцам
0
|
|
| 09.09.2016, 09:12 | |
|
мммммммм, во первых я написал Fields[].Names - это вроде и есть заголовки столбцов
во вторых кто вам мешает перебрать весь грид и вставить его в базу? код ваш не смотрел, покажите примерно в чем проблема
0
|
|
|
60 / 60 / 26
Регистрация: 30.05.2016
Сообщений: 293
|
|
| 09.09.2016, 09:45 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 20.09.2013
Сообщений: 50
|
|
| 09.09.2016, 11:46 [ТС] | |
|
qwertehok, что то я не обратил на это внимание. Весь грид перебираю с помощью такого цикла, если я правильно понял Вас: .DataSource.DataSet.First; for I:= 0 to DBGrid.DataSource.DataSet.RecordCount do. Запись в access происходит так: adotable1.fieldbyname('id').asstring:=db grid1.datasource.dataset.fieldbyname('id ').asstring. То есть со столбца 'id' в dbgrid, я записываю данные в одноимённый столбце в access. Что б мои кож работал мне нужно так же переименовать в access столбцы так же, как они именуются в dbf файле. А мне нужно что бы сразу без всего этого. Просто я не знаю как это все осуществить
0
|
|
|
0 / 0 / 0
Регистрация: 20.09.2013
Сообщений: 50
|
|
| 09.09.2016, 12:54 [ТС] | |
|
qwertehok, хорошо спасибо, то есть запись в акцесс будет происходить так adotable1.fields[0]:=dbgrid.datasource.dataset.fields[0] и так же с первым столбцом? А вот теперь другой вопрос что делать если мне заранее не известно количество столбцов. Мне нужно просто открыть dbf файл и сразу же сохранить его в Access и без разницы сколько столбцов какое у них название
0
|
|
|
3763 / 2271 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
|
|
| 11.09.2016, 22:30 | |
|
А нафига козе баян? Зачем в этом процессе Delphi нужен? Акцес прекрасно умеет сам импортировать dbf-файлы.
0
|
|
|
W
115 / 115 / 33
Регистрация: 16.04.2013
Сообщений: 750
|
|
| 12.09.2016, 09:48 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 20.09.2013
Сообщений: 50
|
|
| 13.09.2016, 19:15 [ТС] | |
|
Пытливый, задание такое
Добавлено через 12 часов 56 минут qwertehok, с этим разобрался, теперь осталось присвоить эти имена в акцесс, как я понял это можно сделать с помощью create table, нужно имена таблиц засунуть в массив, и потом через create table создать в акцесс таблице столбцы, я правильно шагаю?
0
|
|
| 14.09.2016, 08:41 | |||||||
|
ЗЫ create table нужен для создания таблицы в базе данных например
как видно - передавать нужно не только имена колонок, но их тип. ты сможешь определить тип колонки?
0
|
|||||||
|
0 / 0 / 0
Регистрация: 20.09.2013
Сообщений: 50
|
|
| 14.09.2016, 09:16 [ТС] | |
|
qwertehok, ну с этим я разобрался, спасибо, просто таблицу примера вашего я создать могу, но что делать если у меня данные в массиве array of string. Как мне задать имена столбцов и их тип? Подскажите
0
|
|
| 14.09.2016, 09:26 | |||||||
|
нужно пройтись по dbf
далее можно сразу считывать ее в БД ИМХО заносить их в массив - только тратить время
0
|
|||||||
|
0 / 0 / 0
Регистрация: 20.09.2013
Сообщений: 50
|
|||||||||||
| 14.09.2016, 20:42 [ТС] | |||||||||||
|
qwertehok,я знаю что с массивом гемор, ну условие задания такое, что ж поделаешь ))но все же спасибо
Добавлено через 10 часов 36 минут Может кто сталкивался и знает, подскажите. В общем создаю двумерный массив array of string. В [i] записываю имена столбцов с помощью
в [j] записываю типы столбцов с помощью
0
|
|||||||||||
|
0 / 0 / 0
Регистрация: 20.09.2013
Сообщений: 50
|
|
| 14.09.2016, 22:42 [ТС] | |
|
qwertehok, а можно по подробнее, как это сделать догадываюсь, с исполнением не получается.
0
|
|
| 15.09.2016, 09:11 | ||||||
|
так как i=j то можно сделать так
0
|
||||||
|
0 / 0 / 0
Регистрация: 20.09.2013
Сообщений: 50
|
|
| 16.09.2016, 12:42 [ТС] | |
|
qwertehok, спасибо огромное
Добавлено через 5 часов 13 минут может кто сталкивался в интернете ничего толкового не нашёл. Мне нужно определить тип полей, я делаю так: создаю массив array of string, определяю тип полей так:for I:=0 to adotable.fieldcount-1 do ctype[i]:= Ctype[i] + adotable.fields[i].datatype. Соответственно он выдаёт ошибку что типы tfieldtype и string не совместимы, как мне тип полей в массив array of string записать. Спасибо за ранее всем, кто откликнется
0
|
|
| 16.09.2016, 12:42 | |
|
Помогаю со студенческими работами здесь
20
Оптовая база: База данных!
Фильтрация данных ADO базы данных, ADO. Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|