Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 06.09.2013, 09:07
nano_bot nano_bot вне форума
Новичок
 
Регистрация: 05.05.2013
Сообщения: 62
Версия Delphi: Delphi 7
Репутация: 10
Вопрос Узнать есть ли введенная строка в БД MySql

Здравствуйте! Есть edit, вводим туда строку нажимаем ок, и нужно узнать есть ли данная запись в БД. Работаю с компонентами MyDAC, по идее это простой select запрос, но как узнать его результат?
Ответить с цитированием
  #2  
Старый 06.09.2013, 14:07
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

+ Query
Код:
query.Close;
Query.SQL.text:='SELECT * FROM table WHERE stolbec = "' + edit1.text + '"';
query.open;
if query.recordcount > 0 then message('Запись есть!');
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")
Ответить с цитированием
Этот пользователь сказал Спасибо Mrak за это полезное сообщение:
nano_bot (07.09.2013)
  #3  
Старый 06.09.2013, 14:17
Аватар для Uniq!
Uniq! Uniq! вне форума
Местный
 
Регистрация: 29.09.2010
Сообщения: 539
Версия Delphi: Delphi XE3
Репутация: 374
По умолчанию

А первичная задача-то какая?
Не допустить попадания в БД повторяющихся значений?


А по факту, это обычный поиск:
Код:
if MyTable1.Locate('Имя колонки',Edit1.text,[]) then
//... понеслась
и не нужно городить кучу кода с запросами.

Цитата:
Сообщение от Mrak
Код:
' ... stolbec = "' + edit1.text + '"';
Код:
' ... stolbec = ' + QuotedStr(Edit1.Text);

Последний раз редактировалось Uniq!, 06.09.2013 в 14:31.
Ответить с цитированием
Этот пользователь сказал Спасибо Uniq! за это полезное сообщение:
nano_bot (07.09.2013)
  #4  
Старый 06.09.2013, 14:34
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

либо:
Код:
Query.SQL.text:='SELECT count(id) rec_count FROM table WHERE stolbec = "' + edit1.text + '"';
в поле "rec_count" будет количество одинаковых записей

Цитата:
Сообщение от Uniq!
и не нужно городить кучу кода с запросами
тогда уж создать уникальный индекс и вообще клиентам не заморачиваться
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
Этот пользователь сказал Спасибо NumLock за это полезное сообщение:
nano_bot (07.09.2013)
  #5  
Старый 06.09.2013, 17:19
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

Цитата:
Сообщение от Uniq!
и не нужно городить кучу кода с запросами.
хех, по-вашему, лучше использовать таблицы, а не запросы?

Цитата:
Сообщение от Uniq!
Код:
' ... stolbec = ' + QuotedStr(Edit1.Text);
да хоть #39
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")

Последний раз редактировалось Mrak, 06.09.2013 в 17:23.
Ответить с цитированием
Этот пользователь сказал Спасибо Mrak за это полезное сообщение:
nano_bot (07.09.2013)
  #6  
Старый 06.09.2013, 18:37
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Можно попробовать try except использовать при уникальном индексе на таблице.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Этот пользователь сказал Спасибо Страдалецъ за это полезное сообщение:
nano_bot (07.09.2013)
  #7  
Старый 06.09.2013, 23:02
Аватар для Uniq!
Uniq! Uniq! вне форума
Местный
 
Регистрация: 29.09.2010
Сообщения: 539
Версия Delphi: Delphi XE3
Репутация: 374
По умолчанию

Цитата:
Сообщение от NumLock
тогда уж создать уникальный индекс и вообще клиентам не заморачиваться

Я лишь предположил, что автору нужна уникальность.
Ответить с цитированием
Этот пользователь сказал Спасибо Uniq! за это полезное сообщение:
nano_bot (07.09.2013)
  #8  
Старый 07.09.2013, 07:51
nano_bot nano_bot вне форума
Новичок
 
Регистрация: 05.05.2013
Сообщения: 62
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Всем спасибо за помощь! Разобрался!
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 01:29.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025