Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
Как создать поле serial, если в этой таблице уже есть данные?
|
|||
|---|---|---|---|
|
#18+
В мануале написано, что нельзя добавить в таблицу поле типа сериал, если в таблице уже есть данные :( Есть ли способы решения этой проблемы? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 23.06.2004, 16:23 |
|
||
|
Как создать поле serial, если в этой таблице уже есть данные?
|
|||
|---|---|---|---|
|
#18+
alter table t1 add(f1 integer); update t1 set f1=rowid where 1=1; alter table t1 modify (f1 serial not null); create unique index idx1 on t1(f1); update statistics for table t1; ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 23.06.2004, 17:17 |
|
||
|
Как создать поле serial, если в этой таблице уже есть данные?
|
|||
|---|---|---|---|
|
#18+
Создай пустую таблицу с такой же структурой но еще добавь к ней serial и перезалей из исходной данные. Если данных очень много, придется заморочиться с raw table во избежание длинной транзакции. Потом удали исходную таблицу и переименуй новую. Излишне напоминать, что если данные в таблице представляют ценность, то перед перезаливкой следует сделать выгрузку данных и сохранить структуру таблицы (на всякий случай). За мир во всем Мире! ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 23.06.2004, 17:20 |
|
||
|
Как создать поле serial, если в этой таблице уже есть данные?
|
|||
|---|---|---|---|
|
#18+
olleg , спасибо! Все ОК. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2004, 11:44 |
|
||
|
Как создать поле serial, если в этой таблице уже есть данные?
|
|||
|---|---|---|---|
|
#18+
Фокус с rowid не прокатит если таблица фрагментирована. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2004, 14:16 |
|
||
|
Как создать поле serial, если в этой таблице уже есть данные?
|
|||
|---|---|---|---|
|
#18+
зато при переливании в другую таблицу надо еще не забыть про констрайнты и триггеры. Да и необязательно использовать rowid можно написать небольшую хранимую процедуру, которая упорядочить как нибудь таблицу и инкрементом заупдэйтит поле int. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.06.2004, 14:56 |
|
||
|
|

start [/forum/topic.php?fid=44&msg=32575592&tid=1609246]: |
0ms |
get settings: |
8ms |
get forum list: |
12ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
27ms |
get topic data: |
8ms |
get forum data: |
2ms |
get page messages: |
39ms |
get tp. blocked users: |
1ms |
| others: | 13ms |
| total: | 114ms |

| 0 / 0 |
