0 / 0 / 0
Регистрация: 01.01.2008
Сообщений: 106

Удаление записи из dbf-файла в ADO. Query too complex

07.01.2008, 16:51. Показов 2140. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Наблюдается странная вещь...Записи добавляются в файл дбф но не удаляются...

появляется ран тайм еррор и говорит Query too complex и указывает на строчку с delete
как это лечить?

Пишу:
Visual Basic
1
2
3
row_pos = Me.MSHFlexGrid1.RowSel
Personal_data.Recordset.move row_pos, 1
Personal_data.Recordset.Delete
Строка коннекта:
Visual Basic
1
2
cn.ConnectionString = 'DSN=dBASE files;Mode=Read|Write;DBQ=c:FOXING;DefaultDir=c:FOXING;DriverId=21;FIL=dBase III;MaxBufferSize=512;PageTimeout=5'
cn.Open
Помогите плиз..
Всем заранее спасибо..
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.01.2008, 16:51
Ответы с готовыми решениями:

ADO Query Удаление записей
Привет всем. Реализовано удаление из таблиц БД Access (через ADO) путем перебора. Записей бывает более 100 тыс. Вот кусок кода: ...

Удаление записей в dbf с использованием ADO
Делаю 'cn - Connection cn.Execute ('DELETE * FROM spr.dbf') Записи помечаются на удаление. А как сделать, чтобы они физически...

Как открыть dbf-базу для записи, используя ADO?
Пишу Set oCN = New ADODB.Connection Set oRS = New ADODB.Recordset oCN.ConnectionString = 'Provider=MSDASQL.1;Persist Security...

7
Anri
07.01.2008, 17:40
а попробуй после Delete написать
Visual Basic
1
Personal_data.Recordset.Update
0 / 0 / 0
Регистрация: 01.01.2008
Сообщений: 106
08.01.2008, 08:16  [ТС]
Писал...
Все равно Query too complex
Что не так не понятно (

И еще, если определять rs as ADODC.recordset
cn as ADODC.connection
то вообще тогда даже добавлять записи не удается...
Строка коннекта как и в предыджущем сообщении.

Подскажите кто может
0
0 / 0 / 0
Регистрация: 28.10.2007
Сообщений: 160
08.01.2008, 11:11
Всё пашет
Visual Basic
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
Private Sub cmdExit_Click()
    'Set frmDelTable = Nothing
    Unload Me
End Sub
 
Private Sub Form_Load()
    Dim ent_table_name As String, all_table_name As String
    ent_table_name = Left(frmMain.application_cfg.GetValue('txtEnteringTableRegistr'), Len(frmMain.application_cfg.GetValue('txtEnteringTableRegistr')) - 4)
    all_table_name = Left(frmMain.application_cfg.GetValue('txtCommonTable'), Len(frmMain.application_cfg.GetValue('txtCommonTable')) - 4)
    AdodcDel.ConnectionString = 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=' & App.Path & ';Extended Properties=DBase IV'
    AdodcDel.RecordSource = 'Select * From ' & ent_table_name
    txtNRee.DataField = 'REE_NAME'
    txtDateRee.DataField = 'REE_DATE'
    cn_out.Open 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=' & App.Path & ';Extended Properties=DBase III'
    rs_out.Open 'Select * from ' & all_table_name, cn_out, adOpenStatic, adLockOptimistic, adCmdText
End Sub
 
Private Sub cmdDel_Click()
    rs_out.MoveFirst
    MousePointer = vbHourglass
    Do Until rs_out.EOF
        If rs_out.Fields('N_REE') = txtNRee.Text Then
            rs_out.Delete
        End If
    rs_out.MoveNext
    Loop
    AdodcDel.Recordset.Delete
    AdodcDel.Recordset.MoveNext
    MousePointer = vbNormal
End Sub
 
Private Sub Form_Unload(Cancel As Integer)
    rs_out.Close
    cn_out.Close
    Set rs_out = Nothing
    Set cn_out = Nothing
End Sub
0
0 / 0 / 0
Регистрация: 01.01.2008
Сообщений: 106
08.01.2008, 13:04  [ТС]
насколько я понимаю у тебя AdodcDel это контрол на форме??
а rs_out as ADODC.recordset??
cn_out as ADODC.connection??

если у тебя есть аська то можно связаться 130020631
я уже кажется разобрался с датой... твой вопрос из форума..
0
0 / 0 / 0
Регистрация: 28.10.2007
Сообщений: 160
08.01.2008, 13:18
Мне за аську бошку отобьют сотрудники службы безопасности. Я работаю в центральном аппарате крупного банка. За дату спасибо, я похоже въехал - надо заворачивать её решёткой: #1/1/2001#
ADODCDel - это контрол на форме.
0
0 / 0 / 0
Регистрация: 01.01.2008
Сообщений: 106
08.01.2008, 13:30  [ТС]
Как тебе удается подключаться к Dbase файлам с помощью
Provider=Microsoft.Jet.OLEDB.4.0??? он у меня ругается на это дело..
Но у меня версия 3.51 этого провайдера, оно понимает только access фйлы ((

Беда! Если использовать контрол Adodc1 то с ним удается добавлять записи в базу а удалять нет...
Если же использовать программную реализацию без контрола Адодс
то даже добавлять недает!
Все свойства перековырял! ниче не помогоет!
У нас кажется общая проблема с этими тупыми ДБФ файлами.
мое мыло djinnwalker@yandex.ru если потом будет что сказать то напиши пожалуста.
0
0 / 0 / 0
Регистрация: 28.10.2007
Сообщений: 160
08.01.2008, 13:41
У меня ещё работает:
Visual Basic
1
AdodcDel.ConnectionString = 'Provider=MSDASQL.1;Persist Security Info=False;Data Source=dBASE Files;Initial Catalog=' & App.Path
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.01.2008, 13:41
Помогаю со студенческими работами здесь

Помогите с подключением DBF-файла через ADO в NT
Помогите кто-нибудь! Делаю следующее Set cn = New ADODB.Connection cn.Open 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=' &...

Помогите с подключением DBF-файла через ADO в NT
Помогите кто-нибудь! Делаю следующее Set cn = New ADODB.Connection cn.Open 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=' &...

Как удалить запись из dbf файла в ADO?
Использую АДО... таблица Dbase III... Записи добавляются без проблем, но удалять не хочет никак... вот код row_pos =...

ADO+MS SQL: как узнать количество обработанных строк при insert в ADO Query?
Добрый день. При выполнении запроса в MS SQL insert into ..(,,) select 0,20,'Text' where not exists (select 1 from .. where...

Загрузить помеченные на удаление записи из dbf
Импортирую dbf-файл VFP, используя провайдер Microsoft OLE DB Provider for Visual FoxPro Set cnn =...


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

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

Новые блоги и статьи
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды "Заполнить" и "Очистить" на форме документа
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". На примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных выбран регистр накопления, в. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru