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

Хочу в default value таблицы уникальный плейсхолдер, ничего умнее не придумал чем

08.06.2025, 15:51. Показов 1218. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет! Есть что-то более надежное (именно на уровне значения по умолчанию) для генерации временного уникального плейсхолдера?
Visual Basic
1
=Replace(CLng(Replace(Timer();",";""))+Rnd();",";"")
Важно чтобы решение оставалось работоспособным при массовой вставке строк и принималось таблицей как дефолтное значение, которое устроет как PK.
Желательно укладывающееся в "Длинное целое".

P.s. То обстоятельство, что раз в сутки Timer начинает повторяться для меня, вроде как, не является проблемой, т.к. это временный плейсхолдер на время ожиданий пока не запустится VBA-код, меняющий плейсхолдер, после того как завершится вставка.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.06.2025, 15:51
Ответы с готовыми решениями:

Умнее не придумал, кто может образумить?
Через "ректальный" способ реализована такая вещь: база заполняется записями (пара столбцов и...

Собственная функцию в свойстве "Default Value" для поля таблицы?
Всех с Новым годом!) Кто знает, как функцию собственного сочинения можно использовать в качестве...

Default Value в SQL
Здравствуйте! Подскажите, пожалуйста... У меня такая проблема... Имеется инструкция на создание...

3
164 / 38 / 7
Регистрация: 24.08.2014
Сообщений: 540
22.06.2025, 12:46
MikiRose, для генерации временного уникального плейсхолдера в Access/VBA есть несколько более надежных подходов, чем использование Timer() и Rnd(), например:

Использование функции GetTickCount (Windows API)
Visual Basic
1
2
3
4
5
Private Declare PtrSafe Function GetTickCount Lib "kernel32" () As Long
 
Function GenerateTempID() As String
    GenerateTempID = "TEMP_" & GetTickCount() & "_" & Int(Rnd() * 10000)
End Function
Комбинация даты и случайного числа
Visual Basic
1
2
3
4
5
Function GenerateTempID() As String
    Dim timestamp As String
    timestamp = Format(Now, "yyyymmddhhnnss") & Format(Timer, "000")
    GenerateTempID = "TEMP_" & timestamp & "_" & Right("0000" & Int(Rnd() * 10000), 4)
End Function
Использование GUID (глобально уникальный идентификатор)
Visual Basic
1
2
3
Function GenerateGUID() As String
    GenerateGUID = Mid$(CreateObject("Scriptlet.TypeLib").GUID, 2, 36)
End Function

Улучшенная версия вашего подхода
Visual Basic
1
2
3
4
5
6
Function GenerateTempID() As String
    Static counter As Long
    counter = counter + 1
    GenerateTempID = "TEMP_" & Format(Now, "yyyymmddhhnnss") & "_" & _
                    Right("0000" & CLng(Timer * 10000), 4) & "_" & counter
End Function
1
Эксперт MS Access
 Аватар для alvk
7459 / 4592 / 302
Регистрация: 12.08.2011
Сообщений: 14,380
27.06.2025, 11:39
Цитата Сообщение от MikiRose Посмотреть сообщение
плейсхолдер
это что?
Цитата Сообщение от MikiRose Посмотреть сообщение
которое устроет как PK.
Желательно укладывающееся в "Длинное целое".
счётчик
0
ᴁ ©
Эксперт MS Access
 Аватар для АЕ
4159 / 2448 / 508
Регистрация: 13.12.2016
Сообщений: 8,320
Записей в блоге: 5
27.06.2025, 12:33
Цитата Сообщение от MikiRose Посмотреть сообщение
Хочу в default value таблицы уникальный плейсхолдер, ничего умнее не придумал чем
Все давно придумано. Называется счетчик. alvk, уже сказал.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.06.2025, 12:33
Помогаю со студенческими работами здесь

Ошибка 1067 - Invalid default value
Здравствуйте. Ситуация такая: есть таблица, я в нее добавляю один столбец ALTER TABLE `article`...

Ошибка «Field "ххх" doesn’t have a default value»
Ошибка «Field xxx doesn’t have a default value»,делаю базу данных и не могу заполнить таблицу Rooms

Ошибка Cannot convert a char value to money. The char value has incorrect syntax
В отчете (ниже) появляется ошибка Cannot convert a char value to money. The char value has...

Как добавить запись в БД с option по value (не значение value)
Есть в БД список стран и городов, вывожу их в select: <option value=1>Россия</option>. Цель такова,...

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru