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

VB Проверка на уникальность, при добавлении новой записи

07.11.2016, 13:41. Показов 2373. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всех приветствую.

Столкнулся с небольшой проблемой проверки на уникальность (поле "Номер" ) при добавление в базу.

В чем суть

Загружаем данные из txt файла, и проверяем поле "Номер" если такой номер уже есть то данная запись не вносится в базу а в конце загрузки выдается сообщение о дубле.

Код проверки работает, я не могу понять как сделать так чтобы он не заносил "дубли" в базу

Microsoft Access 2013




Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
Sub test()
 
Dim str As String
Dim Дата As String
Dim Номер As String
Dim path  As String
Dim Filepath As String
Dim rs As ADODB.Recordset
 
 ' Вызов диалога для выбора файла
 
 
    Dim strFile As String, strFilter As String
strFilter = "TXT (*.txt)|All Files (*.*)|*.*||"
WizHook.Key = 51488399
WizHook.GetFileName 0, "AppName", "DlgTitle", "", strFile, "c:", strFilter, 0, 0, 0, True
'DeBug MsgBox
'MsgBox strFile
Open strFile For Input As #1
 
 
Do While Not EOF(1)
    Line Input #1, str
     If Mid(str, 1, InStr(str, "=")) = "Дата=" Then
          Дата = Mid(str, InStr(str, "=") + 1)
      End If
     If Mid(str, 1, InStr(str, "=")) = "Номер=" Then
          Номер = Mid(str, InStr(str, "=") + 1)
      End If
 
     'Если встречаем "КонецДокумента" то записываем в базу
  If str = "КонецДокумента" Then
 
  'Создаем рекордсет
      Set rs = New ADODB.Recordset
  'Открываем таблицу
      rs.Open "test_import", CurrentProject.Connection, adOpenDynamic, adLockOptimistic
 
 
   'Проверка уникальности значения
 
Dim a
a = Nz(DLookup("Номер", "test_import", "Номер = '" & Номер & "'"), 0) 
If a = 0 Then
 
Else
MsgBox "Такая запись уже есть "
 
'Exit Sub
End If
 
 
'Записываем данные
 
  With rs
      .AddNew
 
      .Fields("Дата") = Дата
      .Fields("Номер") = Номер
 
      .Update
  End With
 
  End If
  Loop
 
  'Закрываем файл
Close #1
 
'Просто сообщение
MsgBox "Загружено"
 
End Sub
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.11.2016, 13:41
Ответы с готовыми решениями:

Проверка на уникальность поля, при добавлении новой записи
Помогите, плиз. Есть форма добавления записей в таблицу. Есть некое уникальное поле, при добавлении записи в таблицу, вводе значения в...

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

Ошибка при добавлении новой записи в подчиненной форме
Ошибка возникает при добавлении новой записи в подчиненной форме Form2

3
9 / 9 / 5
Регистрация: 19.01.2016
Сообщений: 33
07.11.2016, 17:19
Лучший ответ Сообщение было отмечено dley как решение

Решение

Начиная с 40-й сроки и до конца :
....
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
'Проверка уникальности значения
 
Dim a
a = Nz(DLookup("Номер", "test_import", "Номер = '" & Номер & "'"), 0) 
If a = 0 Then
   'Записываем данные
 
  With rs
      .AddNew
 
      .Fields("Дата") = Дата
      .Fields("Номер") = Номер
 
      .Update
  End With
  
Else
MsgBox "Такая запись уже есть "
 
'Exit Sub
End If
 
 
 
  End If
  Loop
 
  'Закрываем файл
Close #1
 
'Просто сообщение
MsgBox "Загружено"
 
End Sub
0
Эксперт MS Access
 Аватар для alvk
7459 / 4592 / 302
Регистрация: 12.08.2011
Сообщений: 14,380
08.11.2016, 03:07
Не надо else, вы же по всем записям идёте.

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
Sub test()
Dim a as integer 
Dim str As String
Dim Дата As String
Dim Номер As String
Dim path  As String
Dim Filepath As String
Dim rs As ADODB.Recordset
 
 ' Вызов диалога для выбора файла
 
 
  Dim strFile As String, strFilter As String
 
  Set rs = New ADODB.Recordset
  'Открываем таблицу
  rs.Open "test_import", CurrentProject.Connection, adOpenDynamic, adLockOptimistic
 
  strFilter = "TXT (*.txt)|All Files (*.*)|*.*||"
  WizHook.Key = 51488399
  WizHook.GetFileName 0, "AppName", "DlgTitle", "", strFile, "c:", strFilter, 0, 0, 0, True
  Open strFile For Input As #1
Do While Not EOF(1)
    Line Input #1, str
     If Mid(str, 1, InStr(str, "=")) = "Дата=" Then
          Дата = Mid(str, InStr(str, "=") + 1)
      End If
     If Mid(str, 1, InStr(str, "=")) = "Номер=" Then
          Номер = Mid(str, InStr(str, "=") + 1)
      End If
  
 
   'Проверка уникальности значения
  a = Nz(DLookup("Номер", "test_import", "Номер = '" & Номер & "'"), 0) 
  If a = 0 Then
    With rs
      .AddNew
      .Fields("Дата") = Дата
      .Fields("Номер") = Номер
      .Update
    End With
  End If
Loop
 
  'Закрываем файл
Close #1
 
'Просто сообщение
MsgBox "Загружено"
 
End Sub
1
0 / 0 / 0
Регистрация: 28.01.2013
Сообщений: 6
08.11.2016, 12:20  [ТС]
Yuriy_Tevt, alvk,

Cпасибо за помощь.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.11.2016, 12:20
Помогаю со студенческими работами здесь

Ошибка при добавлении из подчиненной формы новой записи в таблицу
Помогите исправить ошибку. База данных создана для ввода информации по договорам и приложениям к ним для контрагентов через форму РП...

Как вставить текущую дату в форму и в таблицу через выражения при добавлении новой записи
Как вставить текущую дату в форму и в таблицу через выражение(построитель выражений) при добавлении новой записи? В приложенном...

Как сделать чтобы при добавлении новой записи в табилцу заносилось "текущая ДатаВремя" правильно?
Настройки таблицы, исходное состояние таблицы - см. скрин. 1. ДатаВремя для новой записи автоматически сгенерированное таблицей -...

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

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
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, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru