Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  00:02[Войти] | [Зарегистрироваться]
Ответ на вопрос № 43951

Вопросы с аналогичными сообщениями об ошибках:
  • Dataset not in edit or insert mode (31)

    20-07-2006 09:13
    Здравстуйте уважаемые жители королевства.

    Пытаюсь записать что-то в excel таблицу через ADO. Использую для этого компонент TADOTable (в этом есть производственная необходимость).


    procedure TForm1.Button1Click(Sender: TObject);
    var
      ADOTable :TADOTable;
    begin
      ADOTable := TADOTable.Create( nil );
      with ADOTable do
        try
          ConnectionString := 'Provider=Microsoft.Jet.OLEDB.4.0;' +
                              'Data Source=D:\Temp\P000720.b07.xls;' +
                              'Mode=ReadWrite;' +
                              'Extended Properties="Excel 8.0;HDR=Yes;"';
          TableName := '[Лист1$]';
          Open;
          Edit;
          AppendRecord( [ '1', '2', '3', '4' ] );
          Post; {Dataset not in edit or insert mode}
          Close;
        finally
          if Active then
            Close;
          end;
    end;



    Post выдает следующий exception "Dataset not in edit or insert mode". При том, если использовать TADOCommand + SQL, с той же ConnectionString - все нормально.

    Подскажите пожалуйста, где я не прав.

    Заранее благодарен.

    [+] Добавить в избранные вопросы

    Отслеживать ответы на этот вопрос по RSS

    Ответы:


    Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
    Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

    04-08-2006 03:31
    Про IMEX http://www.sqldts.com/default.aspx?254

    04-08-2006 03:09
    На счет "Insufficient key column information for updating or refreshing"... Дело в том, что инструкция UPDATE включает в себя все поля таблицы (см. св-во TField.ProviderFlags). Если вы добавите в таблицу две одинаковые записи, то сразу получите ошибку. Выход - создать одно ключевое уникальное поле, а остальным полям убрать флаг pfInWhere

    04-08-2006 02:31
    Попробовал - работает. Записи добавляются.
    Строка подключения (уберите IMEX=1 - это для при объединенных ячейках):

    Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Книга123.xls;Extended Properties="EXCEL 8.0;HDR=Yes;";Persist Security Info=False

    При этом:

      object ADOConnection1: TADOConnection
        ConnectionString = 'file name='Книга123.udl'
        LoginPrompt = False
        Mode = cmShareDenyNone
        Provider = 'Microsoft.Jet.OLEDB.4.0'
        Left = 72
        Top = 168
      end

    Т.е. CursorLocation = clUseClient

    21-07-2006 08:27 | Сообщение от автора вопроса
    На дугом форуме мне подсказали использовать CursorLocation clUseServer, вместо clUseClient, это отчасти помогло. Теперь у меня новая проблема.


    procedure TForm1.Button2Click(Sender: TObject);
    var
      ADOTable :TADOTable;
    begin
      ADOTable := TADOTable.Create( nil );
      with ADOTable do
        try
          ConnectionString := 'Provider=Microsoft.Jet.OLEDB.4.0;' +
                              'Data Source=D:\Temp\1.xls;' +
                              'Mode=ReadWrite;' +
                              'Extended Properties="Excel 8.0;HDR=Yes;IMEX=1;"';
          CursorLocation := clUseServer;
          TableName := '[Лист1$]';
          Open;
          AppendRecord( [ 'a', 'b', 'c', 'd' ] ); {Cannot update.  Database or object is read-only}
        finally
          Close;
          end;
    end;



    На AppendRecord возникает exception "Cannot update.  Database or object is read-only".

    Помогите пожалуйста.

    21-07-2006 08:06 | Сообщение от автора вопроса
    C удовольствием, но использование Jet - требование заказчика.

    Спасибо за совет.

    21-07-2006 01:06
    Попробуйте работать с Excel не через Jet, а через ODBC.
     tiv

    20-07-2006 10:33 | Сообщение от автора вопроса
    Да, признаюсь, поторопился.

    Если сделать так:


    procedure TForm1.Button1Click(Sender: TObject);
    var
      ADOTable :TADOTable;
    begin
      ADOTable := TADOTable.Create( nil );
      with ADOTable do
        try
          ConnectionString := 'Provider=Microsoft.Jet.OLEDB.4.0;' +
                              'Data Source=D:\Temp\1.xls;' +
                              'Mode=ReadWrite;' +
                              'Extended Properties="Excel 8.0;HDR=Yes;"';
          TableName := '[Лист1$]';
          Open;
          AppendRecord( [ 'a', 'b', 'c', 'd' ] );
        finally
          if Active then
            Close;
          end;
    end;



    то после закрытия в табличке никаких изменений не остается.

    P.S. Почему-то Refresh после Open выдает "Insufficient key column information for updating or refreshing". Наверняка сдесь скрвается корень проблемы. Но какие ключи могут быть у xls листа... Не понимаю...

    Помогите пожалуйста.

    20-07-2006 10:03
    Ну не нужен AppendRecord'у Edit...Post! Хелп читать уже не нужно?

    Call AppendRecord to create a new, empty record at the end of the dataset, populate it with the field values in Values, and post the values to the database or change log.

    Добавьте свое cообщение

    Вашe имя:  [Войти]
    Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
    контрольный вопрос:
    Жили у бабуси два веселых гуся. Один белый, другой КАКОЙ?
    в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
    Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
    Тип сообщения:
    Текст:
    Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Вопросы с аналогичными сообщениями об ошибках:
  • Dataset not in edit or insert mode (31)


    Страница избранных вопросов Круглого стола.
  •   
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования