Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
0 / 0 / 0
Регистрация: 22.12.2017
Сообщений: 218

Ошибка: cannot perform this operation on an open dataset

05.04.2018, 09:09. Показов 1990. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго дня! прописываю в clientdataset такой запрос:
Delphi
1
2
3
4
5
6
7
8
9
10
StandDS.CreateDataSet;
StandDs.Active :=False;
StandDS.CommandText := 'SELECT Okp.Klass, Stand.*, Gost.Gost_ID';
StandDS.CommandText := 'FROM Standart.dbo.Stand, Standart.dbo.Gost, Standart.dbo.Okp';
StandDS.CommandText := 'WHERE not EXISTS ( SELECT 0 FROM  КТД.dbo.stBOReferences V';
StandDS.CommandText := 'WHERE V.stGUID='STD^'+CAST(Stand.Stand_ID as varchar(20))';
StandDS.CommandText := 'or V.stGUID='ERE^'+CAST(Stand.Stand_ID as varchar(20))) and Gost.Gost_Id =30 and';
StandDS.CommandText := 'Stand.Gost_Id=Gost.Gost_Id AND Stand.Okp_Id=Okp.Okp_Id';
StandDS.Execute;
StandDS.Active :=True;
ошибка: cannot perform this operation on an open dataset. как правильно оформить и возможно ли так оформить?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.04.2018, 09:09
Ответы с готовыми решениями:

Cannot perform this operation on an open dataset
Нужно отредактировать запись по полю с номером 10, выдает ошибку "Cannot perform this operation on an open dataset" Подскажите что...

EDataBaseError with message 'Table2:Cannot perform this operation on an open dataset'
Table2.DatabaseName:=GetCurrentDir+'\'; Table2.TableName:=IntToStr(DBComboBox1.ItemIndex+1)+ '.db'; Table2.Active:=true; ...

Ошибка cannot perform this operation on a closed dataset
Доброго времени! Релизовывал алгоритм удаления пользователя из бд, почему-то пишет, что датасет закрыт, хотя он при нажатии кнопки...

14
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
05.04.2018, 09:35
поток сознания впечатляет. может стоит лекции хоть одним глазом глянуть?
0
5961 / 4537 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
05.04.2018, 09:36
двойные кавычки нужны там где ты добавляешь текст в запросе
0
0 / 0 / 0
Регистрация: 22.12.2017
Сообщений: 218
05.04.2018, 09:57  [ТС]
qwertehok, да, спасибо! это поправила конечно. но ошибка есть...

Добавлено через 56 секунд
Цитата Сообщение от pincet Посмотреть сообщение
может стоит лекции хоть одним глазом глянуть?
вообще в первый раз работаю с clientdataset, читала, что это аналог Query
0
5961 / 4537 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
05.04.2018, 10:14
9 И 10 строка лишняя
или 9 или 10
0
 Аватар для ZfoxAK
670 / 560 / 242
Регистрация: 26.11.2012
Сообщений: 2,191
05.04.2018, 10:32
Delphi
1
2
3
4
5
6
7
8
9
StandDS.CreateDataSet;
StandDs.Active :=False;
StandDS.CommandText := 'SELECT Okp.Klass, Stand.*, Gost.Gost_ID';
StandDS.CommandText := 'FROM Standart.dbo.Stand, Standart.dbo.Gost, Standart.dbo.Okp';
StandDS.CommandText := 'WHERE not EXISTS ( SELECT 0 FROM  КТД.dbo.stBOReferences V';
StandDS.CommandText := 'WHERE V.stGUID='STD^'+CAST(Stand.Stand_ID as varchar(20))';
StandDS.CommandText := 'or V.stGUID='ERE^'+CAST(Stand.Stand_ID as varchar(20))) and Gost.Gost_Id =30 and';
StandDS.CommandText := 'Stand.Gost_Id=Gost.Gost_Id AND Stand.Okp_Id=Okp.Okp_Id';
ShowMessage(StandDS.CommandText);
так будет выглядеть твой запрос.
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
05.04.2018, 10:41
зарадидля ShowMessage. Тут даже шар не нужен
Цитата Сообщение от ZfoxAK Посмотреть сообщение
StandDS.CommandText := 'Stand.Gost_Id=Gost.Gost_Id AND Stand.Okp_Id=Okp.Okp_Id'
когда ТС поймет умом, чего творит, может и выйдет чего годного
0
 Аватар для ZfoxAK
670 / 560 / 242
Регистрация: 26.11.2012
Сообщений: 2,191
05.04.2018, 10:41
Должно быть примерно так
Delphi
1
2
3
4
5
6
7
8
9
10
var s: string;
begin
s:= 'SELECT Okp.Klass, Stand.*, Gost.Gost_ID';
s :=s + 'FROM Standart.dbo.Stand, Standart.dbo.Gost, Standart.dbo.Okp';
s :=s + 'WHERE not EXISTS ( SELECT 0 FROM  КТД.dbo.stBOReferences V';
s :=s +  'WHERE V.stGUID='STD^'+CAST(Stand.Stand_ID as varchar(20))';
s :=s +  'or V.stGUID='ERE^'+CAST(Stand.Stand_ID as varchar(20))) and Gost.Gost_Id =30 and';
s :=s + 'Stand.Gost_Id=Gost.Gost_Id AND Stand.Okp_Id=Okp.Okp_Id';
StandDS.CommandText:=s;
ShowMessage(StandDS.CommandText);
0
0 / 0 / 0
Регистрация: 22.12.2017
Сообщений: 218
05.04.2018, 12:41  [ТС]
Цитата Сообщение от pincet Посмотреть сообщение
когда ТС поймет умом, чего творит, может и выйдет чего годного
чем ругаться, помогли бы разобраться....
0
5961 / 4537 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
05.04.2018, 12:43
пишешь код, выкладываешь скрин ошибки
0
0 / 0 / 0
Регистрация: 22.12.2017
Сообщений: 218
05.04.2018, 12:47  [ТС]
что сделать, чтобы результатом был не текст запроса, а требуемое в запросе?

Добавлено через 3 минуты
Цитата Сообщение от qwertehok Посмотреть сообщение
выкладываешь скрин ошибки
ошибка устранена, но запрос не отрабатывается
0
5961 / 4537 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
05.04.2018, 12:51
Цитата Сообщение от tsareva Посмотреть сообщение
но запрос не отрабатывается
что это значит? как проверяла? сам запрос оттестирован?
0
0 / 0 / 0
Регистрация: 22.12.2017
Сообщений: 218
06.04.2018, 13:57  [ТС]
Цитата Сообщение от qwertehok Посмотреть сообщение
сам запрос оттестирован?
запрос оттестирован в бд. все ок. при нажатии на кнопку в dbgride пусто.
0
5961 / 4537 / 1094
Регистрация: 29.08.2013
Сообщений: 28,148
Записей в блоге: 3
06.04.2018, 14:26
значит неправильно привязан

без dbgrid проверяла? данные есть?
0
0 / 0 / 0
Регистрация: 22.12.2017
Сообщений: 218
06.04.2018, 15:39  [ТС]
Цитата Сообщение от qwertehok Посмотреть сообщение
данные есть
данные есть. может, правда дбгрид неправильно привязан...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.04.2018, 15:39
Помогаю со студенческими работами здесь

Ошибка: Cannot perform this operation on an empty dataset
Добрый день, удаляю записи из таблицы кодом datasource1.dataset.delete; datasource2.dataset.delete; и когда все данные удалены и...

Ошибка: Cannot perform operation db is not open
Господа знатоки, помогите пожалуйста разобраться! есть база **.GDB в ibexpert открывается без проблем в delphi прописываю путь к базу в...

БД Access ошибка Cannot Perform this operation on a closed dataset
Добрый день...никак не получается исправить ошибку "Can'nt Perform this operation on a closed dataset". Дело в том, что первый...

Ошибка: Cannot perform this operation on an open dataset
Пытаюсь выбрать таблицу с помощью combobox но выходит такая ошибка Cannot perform this operation on an open dataset что делат ? case...

Ошибка "Cannot perform this operation on an open dataset"
Вообщем, проблема в следуещем мне нужно работать паралельно с двумя таблицами из одной базы данных использую 2 ADO Table и 2 DBGrid...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
YAFU@home — распределённые вычисления для математики. На CPU
Programma_Boinc 20.01.2026
YAFU@home — распределённые вычисления для математики. На CPU YAFU@home — это BOINC-проект, который занимается факторизацией больших чисел и исследованием aliquot-последовательностей. Звучит. . .
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru