|
Вопрос # 3 881/ вопрос открыт / |
|
Здравствуйте, подскажите пожалуйста, создаю приложение с автономной базой данных с ClientDataSet и файлом cds, но при выводе записей показывается только последняя из них, как это можно исправить. Спасибо!
Приложение: Переключить в обычный режим-
- cds.Edit;
-
-
-
- cds.Post;
-
-
- cds.First;
- while not cds.Eof do begin
- with ListView1.Items.Add do
- begin
- Caption:=cds.fieldByName('f1').AsString;
- SubItems.Add(cds.fieldByName('f2').AsString);
-
- end;
- cds.Next;
- end;
-
|
Вопрос задал: tystnaden (статус: Посетитель)
Вопрос отправлен: 13 марта 2010, 15:07
Состояние вопроса: открыт, ответов: 1.
|
Ответ #1. Отвечает эксперт: Вадим К
Здравствуйте, tystnaden!
Не надо искать в дебрях DBNavigator каких то тайных методов. там ничего нового не будет. Более того, приведенный выше пример делает именно то, что должен. А именно - он открывает текущую запись на редактирование, редактирует ее и сохраняет. Поэтому, запускайте хоть сто раз, запись будет одна.
А что бы добавить новую запись, надо заменить в коде вызов Edit на вызов insert - он создаст новую пустую запись, и дальнейший код удачно ее отредактирует и сохранит.
Читайте хелпы, там всё написано:)))
|
Ответ отправил: Вадим К (статус: Академик)
Время отправки: 14 марта 2010, 12:47
Оценка за ответ: 5
Комментарий к оценке: Отличный ответ! :)
|
Мини-форум вопроса
Всего сообщений: 17; последнее сообщение — 15 марта 2010, 05:49; участников в обсуждении: 3.
|
Егор (статус: 10-ый класс), 13 марта 2010, 16:40 [#1]:
А в базе точно не одна запись, а несколько?
Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.
— Donald E. Knuth.
|
|
tystnaden (статус: Посетитель), 13 марта 2010, 17:35 [#2]:
Да в базе запись не одна, добавлял много, но выводит только последнюю и все.
|
|
tystnaden (статус: Посетитель), 13 марта 2010, 17:36 [#3]:
listview вывожу так:
cds.First;
while not cds.Eof do begin
with ListView1.Items.Add do
begin
Caption:=cds.fieldByName('f1').AsString;
SubItems.Add(cds.fieldByName('f2').AsString);
end;
cds.Next;
end;
|
|
tystnaden (статус: Посетитель), 13 марта 2010, 17:40 [#4]:
С XML дело обстоит так же, может в структуре файла что то не так
У меня так устроен XML:
<?xml version="1.0" standalone="yes"?> <DATAPACKET Version="2.0"><METADATA><FIELDS><FIELD attrname="f1" fieldtype="string" WIDTH="20"/><FIELD attrname="f2" fieldtype="string" WIDTH="15"/><FIELD attrname="f3" fieldtype="string" WIDTH="30"/><FIELD attrname="f4" fieldtype="string" WIDTH="40"/></FIELDS><PARAMS DEFAULT_ORDER=""/></METADATA><ROWDATA></ROWDATA></DATAPACKET>
После добавления записей еще появляется тэг LOG
|
|
tystnaden (статус: Посетитель), 13 марта 2010, 17:43 [#5]:
Извиняюсь, такой тэг
<PARAMS CHANGE_LOG="1 0 4" DEFAULT_ORDER=""/>
|
|
Егор (статус: 10-ый класс), 13 марта 2010, 17:51 [#6]:
а если попробовать вывод не в ListView? в memo, к примеру?
и вообще, отладчиком пробовали проходить этот код?
Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.
— Donald E. Knuth.
|
|
tystnaden (статус: Посетитель), 13 марта 2010, 18:10 [#7]:
В Memo тоже самое , хотя если у ClientDataset установить IndexName в ChangeIndex то выводит две записи, Отладчик цикл проходит только два раза
|
|
Егор (статус: 10-ый класс), 13 марта 2010, 18:31 [#8]:
Цитата (tystnaden):
Отладчик цикл проходит только два раза
ну судя по симптомам, имеются лишь две записи
а если cds подключить к DBGrid?
Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.
— Donald E. Knuth.
|
|
tystnaden (статус: Посетитель), 13 марта 2010, 18:36 [#9]:
Вот например эта тестовая база файла XML:
<ROWDATA><ROW RowState="5" f1="Edit1" f2="Edit2"/><ROW RowState="13" f1="Edit1" f2="Edit2"/>
<ROW RowState="13" f1="ere" f2="rgr"/>
<ROW RowState="13" f1="11111111111111" f2="wwwwwwwww"/>
<ROW RowState="13" f1="rrrrrrrrr" f2="7 uy y j"/>
<ROW RowState="12" f1="Edit1" f2="Edit2"/></ROWDATA>
DBGrid показывает вообще одну запись, вот эту:
<ROW RowState="13" f1="rrrrrrrrr" f2="7 uy y j"/>
|
|
tystnaden (статус: Посетитель), 13 марта 2010, 18:48 [#10]:
Сейчас исполбзовал DbGrid и DbNavigator, и все што с их использованием сохранил, отоброжаеться, а сохраненное мной по старому все равно показывает одну запись
|
|
Егор (статус: 10-ый класс), 13 марта 2010, 21:17 [#11]:
хм...
а в файле это как отображается? может вы тогда их сохраняете неправильно? где-то по-мелочи накосячили, не заметили?
посмотрите, в чём будет разница, если сохраните "ручками" и через DBGrid
Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.
— Donald E. Knuth.
|
|
tystnaden (статус: Посетитель), 14 марта 2010, 09:39 [#12]:
Вот как раз если DBGrid и DbNavigator использовать то сохраняется нормально, видимо што то не дописываю...
|
|
Егор (статус: 10-ый класс), 14 марта 2010, 09:59 [#13]:
хм...
и всё же, в чём разница-то?
лучше файлы сравнивать hex-редактором
Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.
— Donald E. Knuth.
|
|
tystnaden (статус: Посетитель), 14 марта 2010, 10:09 [#14]:
По всей видимости DbNavigator использует свои способы сохранения данных...попробую узнать их
|
|
tystnaden (статус: Посетитель), 14 марта 2010, 20:30 [#15]:
Спасибо, тепереь работает
|
|
Вадим К (статус: Академик), 14 марта 2010, 23:42 [#16]:
Можно и оценку поставить)
Галочка "подтверждения прочтения" - вселенское зло.
|
|
Егор (статус: 10-ый класс), 15 марта 2010, 05:49 [#17]:
Цитата (Вадим К):
надо заменить в коде вызов Edit на вызов insert
кхм... мда...
до такого я бы не додумался...
как-то думал, что в базе уже есть несколько записей
Опасайтесь багов в приведенном выше коде; я только доказал корректность, но не запускал его.
— Donald E. Knuth.
|
Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.
|