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

Удаление записей

30.06.2016, 20:00. Показов 687. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Удаление разрешить только для такой записи, на которую нет ссылок из дочерних таблиц, есть код, проблема в том, что он возвращает RecordCount >0 для любой записи :
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
procedure TForm5.N2Click(Sender: TObject);
   var a:integer;
begin
DataModule2.ADOQuery1.Close;
DataModule2.ADOQuery1.SQL.Clear;
DataModule2.ADOQuery1.SQL.Add('SELECT * FROM T_osmotr, Incpector WHERE ( T_insp=T_number)');
DataModule2.ADOQuery1.Open;
a:=DataModule2.ADOQuery1.RecordCount;
 
if a <> 0 then
  begin
    MessageDlg('NO DELETE ', mtError,[mbOK], 0);
  end
else
  MessageDlg(' Delete', mtError, [mbOK], 0);
end;
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.06.2016, 20:00
Ответы с готовыми решениями:

Удаление записей
У меня есть главная таблица(Студенты) и две таблицы простых(Языки и Данные).Как сделать так что если я удаляю из таблицы например Языки, то...

Удаление записей
Есть запрос в Access называется &quot;ОборудованиеЗапрос&quot; делаю удаление записей в делфи: DM.tblobr.Delete; Выдает вот токую ошибку:

Удаление записей
База данных Access. Делаю процедуру удаления записи из первой и второй таблиц. И в том дело, что во второй таблице отображаются только те...

8
 Аватар для krapotkin
6847 / 4674 / 1463
Регистрация: 14.04.2014
Сообщений: 20,659
Записей в блоге: 21
30.06.2016, 20:39
и что нужно понять из вашего запроса?
взять все записи из двух таблиц где поле одной равно полю другой

как без порошка семицвета и вытяжки выхухоли узнать про строение
Цитата Сообщение от KMD Посмотреть сообщение
дочерних таблиц
?
0
4 / 4 / 0
Регистрация: 19.07.2015
Сообщений: 96
01.07.2016, 15:58
Цитата Сообщение от KMD Посмотреть сообщение
DataModule2.ADOQuery1.SQL.Add('SELECT * FROM T_osmotr, Incpector WHERE ( T_insp=T_number)');
Попробуй запрос сделать так:
SQL
1
2
3
4
SELECT * FROM T_osmotr
JOIN Incpector ON T_insp = T_number
WHERE T_insp = "' + IntToStr(InspID) + '"
GROUP BY T_insp
InspID - код инспектора, для которого хотите проверить наличие записей в другой таблице

Цитата Сообщение от KMD Посмотреть сообщение
if a <> 0 then
Лучше так:
Delphi
1
if a > 0 then
0
 Аватар для Пытливый
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
02.07.2016, 02:16
в запросе группировка и * не дружат, надо конкретное поле или агрегатную функцию использовать
0
4 / 4 / 0
Регистрация: 19.07.2015
Сообщений: 96
02.07.2016, 08:34
Цитата Сообщение от Пытливый Посмотреть сообщение
в запросе группировка и * не дружат, надо конкретное поле или агрегатную функцию использовать
Я проверил, у меня дружат
0
 Аватар для Пытливый
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
02.07.2016, 10:18
Это где же они у вас дружат? В какой БД? Не встречал что-то такой дружбы.
0
4 / 4 / 0
Регистрация: 19.07.2015
Сообщений: 96
02.07.2016, 10:38
Цитата Сообщение от Пытливый Посмотреть сообщение
Это где же они у вас дружат? В какой БД? Не встречал что-то такой дружбы.
Mysql. Такой запрос объединяет поля. Могу скриншоты дать

SQL
1
SELECT * FROM dir_customers WHERE cstm_deleted=0  GROUP BY cstm_sex;
0
 Аватар для Пытливый
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
02.07.2016, 10:57
Да я верю, но это видимо какой-то изврат специфичный, классический SQL запрещает такое использование. Большинство популярных баз типа Акцеса,MSSQL,Interbase тоже не разрешают такой вольности, насчет Oracle не уверен, там тоже любят поэкспериментировать, но думаю тоже нельзя так делать. Так что лучше не использовать такую запись, во избежании получения вредного навыка.
0
4 / 4 / 0
Регистрация: 19.07.2015
Сообщений: 96
02.07.2016, 11:22
Спасибо, буду знать)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.07.2016, 11:22
Помогаю со студенческими работами здесь

Удаление записей
Доброго времени суток. Меня интересует ответ на такой вопрос : Допустим есть приложение, через которое можно добавить информацию в...

Удаление записей в цикле
delphi+access В программе есть процедура, которая переводит студентов на новый учебный год, в которой записи о &quot;выпущёных&quot;...

Удаление повторяющихся записей
Добрый вечер. Знаю, что до меня создавалась подобная тема, прошу прощения, но нужны ваши свежие ответы. В базе (.mdb) хочу удалить...

Удаление записей в DBGrid
Необходимо удалить из двух разных таблиц информацию об одном читателе, Но сначала нужно удалить читателя из БД, это все ясно. Но как...

Удаление записей в таблице
Здравствуйте! Подскажите, какими способами удобнее удалять выделенные записи в таблице (Но не все записи, а, например, 2-4 записи из ...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
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 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru