Форум программистов, компьютерный форум, киберфорум
Visual C++: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
13 / 13 / 0
Регистрация: 11.10.2011
Сообщений: 116

Запрос на с++

03.08.2012, 14:49. Показов 1404. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго времени суток, подскажите как на с++ организовать запрос, добавляющий в таблицу с 3 интовыми полями данные. Но если вводимые данные совпадают с данными в базе по 3ему полю, то такие данные не вводить. Я просто плохо себе это в с++ представляю..
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.08.2012, 14:49
Ответы с готовыми решениями:

Почему ответ на GET запрос из Python отличается от ответа на GET запрос из HTTP Analyzer
Добрый день. Делаю GET запрос из HTTP Analyzer Указываю только адрес запроса: https://www.nn.ru/community/sp/food/ Получаю ответ -...

Как посмотреть T-SQL запрос который генерирует Entity Framework запрос
как посмотреть T-SQL запрос который генерирует Entity Framework запрос в visual studio 2010, 2012

Как записать запрос так чтобы их запрос суммировался в одну ячейку?
Как записать этот запрос так чтобы их запрос суммировался в одну ячейку? Перепробовал все что знал и все что подсказали, не получается ...

6
 Аватар для Aloir
225 / 225 / 38
Регистрация: 17.12.2010
Сообщений: 713
06.08.2012, 13:35
тебе надо добавить или обновить?
поле в этой таблице или в другой?

ПыСы: если обновить, то как вариант могу предожить на базе написать триггер который будет как раз и проверять эти данные, а запросом делать простой инсерт
0
13 / 13 / 0
Регистрация: 11.10.2011
Сообщений: 116
07.08.2012, 01:01  [ТС]
Цитата Сообщение от Aloir Посмотреть сообщение
тебе надо добавить или обновить?
поле в этой таблице или в другой?
ПыСы: если обновить, то как вариант могу предожить на базе написать триггер который будет как раз и проверять эти данные, а запросом делать простой инсерт
Ну смотри, к примеру такая таблица:
MySQL
1
2
3
4
5
6
7
CREATE TABLE
        `selp` (
            `id` INT(11) NOT NULL AUTO_INCREMENT,
            `name` CHAR(50) NOT NULL,
            `hash` blob NOT NULL,
            PRIMARY KEY(`id`)
        )
Далее, уже непосредственно в c++, ну т.е. в коде я делаю в нее инсерт:
MySQL
1
2
3
4
INSERT INTO
        `selp` (`name`, `hash`)
    VALUES
        ('nature', 48847E5536130C10)
Хотя опять же, как это по-человечески на c++ сделать я пока не нашел. Ну и соответственно по ходу работы программы подобных инсертов могут быть сотни, и соответственно чтобы в базу не писался один и тот же хеш(только с разными названиями), при инсерте нужно проверить третье поле - если в базе уже такой хеш есть, то данный инсерт пропускать. В общем как-то так.
0
 Аватар для Aloir
225 / 225 / 38
Регистрация: 17.12.2010
Сообщений: 713
07.08.2012, 11:30
ну с ходу что пришло тогда в голову - два запроса, один которые проверяет и если он возвращает 1 например то вызывается второй

пойду подумаю еще )) мот че придумается)

Добавлено через 16 минут
ну или написать процедуру и через и кинуть ее на базу, тогда меньше будет кода и быстрее отработает
0
13 / 13 / 0
Регистрация: 11.10.2011
Сообщений: 116
08.08.2012, 17:23  [ТС]
Цитата Сообщение от Aloir Посмотреть сообщение
ну с ходу что пришло тогда в голову - два запроса, один которые проверяет и если он возвращает 1 например то вызывается второй

пойду подумаю еще )) мот че придумается)

Добавлено через 16 минут
ну или написать процедуру и через и кинуть ее на базу, тогда меньше будет кода и быстрее отработает
Можно код, хотя бы приблизительный?
0
 Аватар для Aloir
225 / 225 / 38
Регистрация: 17.12.2010
Сообщений: 713
08.08.2012, 23:13
ну например такие 2 отдельных selecta

SQL
1
SELECT 1 FROM 'SELP' WHERE 'name'  = 48847E5536130C10
если найдет указанный хэш оно вернет 1, делаешь проверку, если там 1 то делаешь insert

SQL
1
2
3
4
INSERT INTO
        `selp` (`name`, `hash`)
    VALUES
        ('nature', 48847E5536130C10)
Добавлено через 21 минуту
ну а если процедурой то примерно такой код, только она под Sybase сделана
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
BEGIN
 DECLARE @ret INTEGER;
 SELECT @ret = 1 FROM 'selp' WHERE 'hash' = @hash
 
 IF @ret <> 1 
  BEGIN
   INSERT INTO 'selp' ('name', 'hash') VALUES (@name, @hash)
   SELECT 1
  END
 SELECT 0
 
 RETURN 1
END
где @name и @hash - входные параметры

процедура тебе вернет 1 если запись добавлена
и 0 если нет
1
 Аватар для talis
794 / 546 / 61
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
12.08.2012, 17:07
Скажите, а ваша СУБД не поддерживает уникальные индексы? Просто можно это третье поле проиндексировать (CREATE UNIQUE INDEX в mysql), и тогда при попытке вставки значения, уже существующего в базе, запрос вернёт ошибку.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.08.2012, 17:07
Помогаю со студенческими работами здесь

Запрос Select T-sql - Вложенный запрос вернул больше одного значения
Нужно посчитать комиссию от сделки. DealShare(комиссия) - поле таблицы agents, supplies - предложения(риелторы клиентам) deals-...

Укомплектовать запрос в один. Запрос маленький проблема для знающего на 30 сек
Всем привет. Возможно кому то для поднятия настроения. Как укомплектовать такой запрос в один SELECT Product.maker, Product.type,...

Есть запрос на вставку в PostgreSQL нужно написать этот запрос в Python
Есть запрос на вставку в PostgreSQL нужно написать этот запрос в Python INSERT INTO &quot;table1&quot; (&quot;ID_table3&quot;,...

Как в sql запрос вставить еще один запрос правильно?
Есть длинный запрос, в котором можете даже не разбираться если не хотите, но выдает он следующее: Запрос: SELECT...

Запрос данных из БД. Один большой запрос или много маленьких?
Есть основная форма, на которой расположен TreeView, содержащий щас 30 ветвей. По щелчке на ветке открываются дочерние формы, на каждой в...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru