С Новым годом! Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
0 / 0 / 1
Регистрация: 24.11.2010
Сообщений: 44
1

Как перезаписать в поле id номера с 1 ++ по возврастающей подряд

31.05.2012, 09:47. Показов 1961. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть две таблицы в них уникальный id он не автоинкремент, а берется мах +1 и делается под этот номер записи в двух таблицах.
Но записи удаляются периодически, в результате номера идут в выводе не подряд, а допустим после 20 идет 23.
Хочу сделать чтобы все id в выводе cтали подряд и после 20 шел уже 21 что была запись по 23му.
Да, если запись под каким либо id удалялась , то удалялась из обоих таблиц соответственно, поэтому соответствие таблиц есть.

Есть какая команда чтобы перенумеровать поле сверху вниз по возрастающей?
Я для двух таблиц выполню команду и соответствие сохранится но уже в номерах будет порядок, без пробелов.
Какие тут подводные камни?
Конечно дамп базы перед процедурой выполню.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.05.2012, 09:47
Ответы с готовыми решениями:

Как написать условие регулярного выражения, чтобы в поле ввода не было 3 подряд идущих пробела?
Нужно условие: let reg = new RegExp("если три подряд идущих пробела");

Определить, является ли последовательность строго возврастающей
1) Дано натуральное число N. Получить все такие натуральные Q , что N делится на Q^2 и не делится...

Как сделать чтобы при смене номера группы поле с материалом обнулялось?
На форме есть 2 поля со списков зависящих друг от друга. В первом ввожу номер группы материала...

Записать в массив В подряд номера положительных элементов
Записать в массив В подряд номера положительных элементов массива ( x1 , x 2 ,...x20 ) .

3
4217 / 3058 / 583
Регистрация: 21.01.2011
Сообщений: 13,205
31.05.2012, 10:10 2
Цитата Сообщение от yok
Есть две таблицы в них уникальный id он не автоинкремент, а берется мах +1
MAX + 1 - это известная засада при многопользовательской работе. Поскольку несколько пользователей могут получить одинаковое значение.

Цитата Сообщение от yok
Хочу сделать чтобы все id в выводе cтали подряд и после 20 шел уже 21 что была запись по 23му.
Забей на это. Иначе этим придется заниматься регулярно, да еще в то время, когда с базой никто не работает.
В конце концов, требование к Id (к primary key) - это уникальность, а есть там пропуски или нет - дело десятое.

PS
Через желание иметь последовательные Id в таблицах проходят практически все начинающие
Однако это малореально и непроизводительно, поэтому производители СУБД не предоставляют для этого встроенных средств
0
0 / 0 / 1
Регистрация: 24.11.2010
Сообщений: 44
31.05.2012, 11:57  [ТС] 3
Спасибо за ответ.

Цитата Сообщение от Grossmeister Посмотреть сообщение
MAX + 1 - это известная засада при многопользовательской работе. Поскольку несколько пользователей могут получить одинаковое значение.
Тут пользователей очень мало. И одновременно почти невозможно. Но спасибо за совет.
Кстати у меня вообще была мысль скрипт перед этой процедурой перенумерованием чтобы блокировал все обращения к базе или на изменение. Т.е. снимается дамп на это время, блокируется на запись и перенумерация.

Вопрос как ее заблокировать ну и сама перенумерация.
Вопрос чисто даже не из за того, стоит ли это делать, а просто раз этим занялся то прояснить надо.
Буду очень признателен за советы и ссылки на инфо.
Спасибо.
0
14 / 3 / 0
Регистрация: 27.07.2018
Сообщений: 97
29.09.2018, 00:54 4
А что если записать всё из таблицы в массив, потом очистить таблицу и снова заполнить из массива. Я тоже начинающий и притом перфекционист.
0
29.09.2018, 00:54
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.09.2018, 00:54
Помогаю со студенческими работами здесь

Переписать в масив В подряд номера отрицательных элементов массива A (20)
переписать в масив В подряд номера отрицательных элементов массива A(20) Var A:array of...

Найти номера 3ех подряд идущих дней с самой жаркой температурой
Дана температура воздуха за каждый день августа. Найти номера 3ех подряд идущих дней с самой жаркой...

Друзья, подскажите, как в классе создать константное поле, ссылочное поле и объектное поле?
Препод на защите лабораторной по классам дал задание большое. В общем-то все пункты я знаю как...

Вывести на экран номера таких двух подряд идущих элементов, произведение которых превышает N
имеется ряд чисел: 2, 4, 6, 8, ... вывести на экран номера таких двух подряд идущих элементов,...

Определить количество и номера рядов, в каждом из которых есть четыре три подряд идущих свободных места
В зрительном зале 25 рядов, в каждом из которых 40 мест. Информация о проданных билетах хранится в...

Формат номера в поле счетчик
Добрый день! Столкнулся со следующей проблемой. В таблице имеется поле счетчик, которое...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Как проводить научные вычисления на Python
InfoMaster 15.01.2025
Python стал одним из наиболее востребованных языков программирования в области научных вычислений благодаря своей простоте, гибкости и обширной экосистеме специализированных библиотек. Научные. . .
Создание игры типа Minecraft на PyGame/Python: пошаговое руководство
InfoMaster 15.01.2025
В данном руководстве мы рассмотрим процесс создания игры в стиле Minecraft с использованием библиотеки PyGame на языке программирования Python. Этот проект идеально подходит как для начинающих. . .
Как создать свою первую игру в стиле Doom на Unreal Engine
InfoMaster 15.01.2025
Разработка шутера от первого лица в стиле классического Doom представляет собой увлекательное путешествие в мир игрового программирования, где сочетаются творческий подход и технические навыки. . . .
Параллельное программировани­е: основные технологии и принципы
InfoMaster 15.01.2025
Введение в параллельное программирование Параллельное программирование представляет собой фундаментальный подход к разработке программного обеспечения, который позволяет одновременно выполнять. . .
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS, Swagger и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru