172 похожих чатов

Как реализовать авто инкремент составного ключа? К примеру у меня таблица

состоит из двух полей (id, user_id). User_id - внешний ключ. И эти два поля должны быть составным ключом.
Например, если юзер один и тот же, то айди инкриминируется, а если новый, то для него отдельно.
Пример: id - user_id:
1 - 14
2 - 14
3 - 14
1 - 23
1 - 65
2 - 23

1 ответов

11 просмотров

Сикенс тут не поможет, потому что юзеров неопределенное количество. Поэтому только через лок. Решил бы я такую задкчу через advisory lock на вставку в эту таблицу с user_id в ключе, брал бы max(id) where user_id=my_user_id и new_id = max(id)+1 . Это 100% рабочее решение. Но в целом я бы присмотрелся к схеме, оч странный составной ключ, возможно вы что-то не то делаете. Запись в таблицу через лок говорит о том, что что-то накостылено

Похожие вопросы

Обсуждают сегодня

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Я вот подумал. SSE выполняет операции максимум с 64-битной точностью. А FPU - всегда с 80-битной. Разве не должно быть FPU точнее тогда?
The Bird of Hermes
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
как быть с принтером? такой подход прокатит?
zamtmn
12
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Я не понимаю, это троллинг или что? Швабрика поддерживают, который буквально пишет на ассемблере взаимодействия с винапи. Я это ещё написал загрузчик и хоть что-то изучаю в о...
Shadow Akira
6
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
Карта сайта