Форум программистов, компьютерный форум, киберфорум
Microsoft Access
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 08.03.2015
Сообщений: 16

Добавление записей в таблицу с условием

08.03.2015, 18:23. Показов 1075. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Подскажите, как добавить записи в таблицу T1, если общее количество записей в таблице не превышает 5.
Знаю, как добавить; знаю, как вывести общее количество записей. Но как это соединить - без понятия. Это надо сделать с помощью sql. Прошу не судить строго, я новичок в базах.

Заранее спасибо.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.03.2015, 18:23
Ответы с готовыми решениями:

Добавление записей в таблицу с условием
Есть рабочая таблица А. Есть временная таблица с данными - Б. Нужно вставить данные из таблицы Б в А. При этом есть логическая...

Добавление записей в таблицу и связанную с ней таблицу, с учётом связи
Имеются 3 таблицы: кабинет id_cab n_cab устройства ...

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

9
Эксперт MS Access
2837 / 1378 / 216
Регистрация: 13.05.2011
Сообщений: 4,220
08.03.2015, 19:25
Цитата Сообщение от Supernaut Посмотреть сообщение
Подскажите, как добавить записи в таблицу T1, если общее количество записей в таблице не превышает 5.
Знаю, как добавить; знаю, как вывести общее количество записей.
Не ясно, что же надо добавить? Может быть объединить?
Покажите Ваш пример.
0
0 / 0 / 0
Регистрация: 08.03.2015
Сообщений: 16
09.03.2015, 21:08  [ТС]
В общем, есть таблица T1. В ней поля P1, P2, P3, P4. Нужно создать запрос на добавление в таблицу записи, если общее количество записей в таблице не превышает 5.
Добавление записи в таблицу сделать могу:

strSQL = "INSERT INTO T1 (P1, P2, P3, P4) values('1', 'qwerty', 'asd', '456')"

А как собственно сделать то же самое, но с проверкой на количество записей?
0
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
09.03.2015, 21:27
Цитата Сообщение от Supernaut Посмотреть сообщение
с проверкой на количество записей?
Visual Basic
1
2
3
4
If Dcount("*", "T1")<5 Then
   strSQL = "INSERT INTO T1 (P1, P2, P3, P4) values('1', 'qwerty', 'asd', '456')"
   Currentdb.Execute strSQL
End If
1
0 / 0 / 0
Регистрация: 08.03.2015
Сообщений: 16
09.03.2015, 21:40  [ТС]
Спасибо огромное! Всё работает, только добавляет не одну запись, а две. Не могу понять, почему..
0
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
09.03.2015, 22:28
Цитата Сообщение от Supernaut Посмотреть сообщение
добавляет не одну запись, а две
Конструкция Insert Into ... Values в принципе может добавлять только одну запись. Следовательно, вторая добавляемая запись происходит по причинам вне показанного кода. Отгадать невозможно. Либо ищите сами, либо выкладывайте БД на форум и местные ищейки разнюхают и доложат.
0
 Аватар для VinniPuh
9129 / 6137 / 593
Регистрация: 27.03.2013
Сообщений: 19,987
09.03.2015, 22:45
Цитата Сообщение от Supernaut Посмотреть сообщение
...добавляет не одну запись, а две...
Скорее всего где то каких то связей в запросах нет, вот и двоится, а будет больше данных, то наверное и троится будет.

Добавлено через 7 минут
Слышал, что какое то Декартово размножение существует, может это оно и есть?
0
0 / 0 / 0
Регистрация: 08.03.2015
Сообщений: 16
09.03.2015, 22:58  [ТС]
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
Sub create_Query()
Dim dbs As Database, qdf As QueryDef
Dim rst As Recordset, strSQL As String
Set dbs = CurrentDb
If DCount("*", "T1") < 5 Then
   strSQL = "INSERT INTO T1 (P1, P2, P3, P4) values('1', 'qwerty', 'asd', '456')"
   CurrentDb.Execute strSQL
Set qdf = dbs.CreateQueryDef("Query4", strSQL)
DoCmd.OpenQuery "Query4"
Else
MsgBox "В таблице 5 или больше записей"
End If
End Sub
Это весь код
0
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
09.03.2015, 23:31
CurrentDb.Execute strSQL уже выполняет запрос!!! А присваивание SQL-выражения запросу Query4 и последующее его открытие выполняют запрос на добавление вторично! Отсюда и вторая запись.

Не нужен этот Query4 вообще. Не создавайте его, не выполняйте. CurrentDb.Execute это надежнее, проще и понятней.

Добавлено через 4 минуты
Кстати, раз уж Вы определили переменную dbs, типа Database, то вместо CurrentDb.Execute уместно пользоваться dbs.Execute
Visual Basic
1
dbs.Execute strSQL
1
0 / 0 / 0
Регистрация: 08.03.2015
Сообщений: 16
10.03.2015, 00:00  [ТС]
Спасибо, теперь всё работает. И мне понятно стало!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.03.2015, 00:00
Помогаю со студенческими работами здесь

Добавление записей в таблицу
Приветствую я только начал изучать html,php,sql. Так вот у меня вопрос, например у меня имеется база данных z123 и в ней таблица zakaz в...

Добавление записей в таблицу
Здравствуйте. Пытаюсь добавить данные в таблицу вот код: OracleCommand command = new OracleCommand(); ...

Добавление записей в таблицу
SqlConnection connection1 = new SqlConnection(&quot;Data Source=.\\SQLEXPRESS;AttachDbFilename=C:\\bd\\bdtest.mdf;Integrated...

Добавление записей в таблицу
Пытаюсь добавить запись в таблицу . Приведу ниже скрины. Как пофиксить то, что у меня свойство UserPhotoId=3, а после команды...

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


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru