|
![]() |
#1 |
Участник
|
Цитата:
почему-то дошло до максимума. то ли глюк, то ли еще. я очистил таблицу (эта все равно чистится) и сбросил счетчик в SystemSequences для этой таблицы в 1. но почему дошло до максимума - загадка. |
|
![]() |
#2 |
Модератор
|
Цитата:
Однако имеем PHP код:
Код: Name NEXTVAL MAXVAL ---------------------------------------- -------------------- -------------------- CUSTTABLE 9223372036854775806 9223372036854775807 VENDTABLE 9223372036854775806 9223372036854775807 VENDBANKACCOUNT 5899128042471217842 9223372036854775807 CUSTBANKACCOUNT 4215181910838106837 9223372036854775807 INVENTTRANS 67646597533403 9223372036854775807 LEDGERJOURNALTABLE 53435931095402 9223372036854775807 LEDGERJOURNALTRANS 53057020090124 9223372036854775807 NUMBERSEQUENCELIST 1333370117650 9223372036854775807 PURCHLINE 1079295926979 9223372036854775807 NUMBERSEQUENCEHISTORY 724040783648 9223372036854775807 (10 row(s) affected)
__________________
This posting is provided "AS IS" with no warranties, and confers no rights. |
|
|
За это сообщение автора поблагодарили: mazzy (2). |
![]() |
#3 |
Модератор
|
Уточнение: В самой таблице [dbo].[SYSTEMSEQUENCES], при остановленном AOS, на SQL Server в БД ручками правим значение в поле NEXTVAL ?
Или используем более "элегантный" способ для выставления следующего RecID для таблицы?
__________________
This posting is provided "AS IS" with no warranties, and confers no rights. |
|
![]() |
#4 |
Участник
|
руками. nextval.
можно и не из EnterPrise Manager, а из аксапты. только надо зайти в компанию Dat. |
|
![]() |
#5 |
Участник
|
Если не ошибаюсь, после этого надо AOS перегрузить (в 4.0 точно требуется).
__________________
Ivanhoe as is.. |
|
![]() |
#6 |
Модератор
|
http://erpkb.com/Axapta/RecId
Цитата:
«Кстати, насчет дырок. Одна из причин их появления – каждый AOS (а так же тольстый клиент и клиент в 2-х звенке) резервирует под себя определенное кол-во recId (для уменьшения обращений к б/д при добавлении новых записей). При его перезагрузке это резервирование сбрасывается и выбирается новый диапазон при загрузке.»
..................... Работает AXAPTA с этой таблицей следующим образом: При вставке первой записи в новую компанию система AXAPTA добавляет в таблицу System Sequences? запись. В поле DATAAREAID устанавливается значение равное идентификатору компании, а в поля MINVAL и NEXVAL записывается единица. Сразу после этого система AXAPTA берет лот номеров (лот в данном случае это – несколько подряд идущих номеров, AXAPTA берет 25). И записывает в поле NEXTVAL следующий свободный номер – 26. Заносит в таблицу, с которой все началось запись с RECID равным 1 и DATAAREAID равным идентификатору компании. После того как номера в лоте заканчиваются, система AXAPTA снова читает таблицу System Sequences?, берет оттуда NEXTVAL как первый номер следующего лота. А в таблицу System Sequences? записывает значение NEXTVAL+25. Таким образом AXAPTA решает две проблемы – каждый пользователь ведет свой лот номеров RECID и значения этого поля не пересекаются, второе – пользователь (вернее его приложение) обращается к таблице System Sequences? один раз на 25 операций вставки и таким образом не возникает ожидания из-за обращения всех к этой таблице. Посморел PHP код:
1680993290137317294 - 1678119797343299707 (2 шт.) 5746991225213500 - 5746991225213520 (~ 200 шт.) 2873498431195913-2969044981147155 (~ 2000 шт. ) 95552187129564- 95552187129568 (5 шт.) 132356740849-132356740883 (~ 100 шт.) 12486884666 - 12486884676 (10 шт.) 7349605052 (1 шт.) 5637145098 - 6207987332 (~ 15 шт.) Записей в CUSTTABLE всего 17 146 шт. Каком образом выбирается диапазон RecId, ну просто ![]()
__________________
This posting is provided "AS IS" with no warranties, and confers no rights. |
|
![]() |
#7 |
Участник
|
но не квинтилионы же...
|
|
![]() |
#8 |
Модератор
|
![]()
__________________
This posting is provided "AS IS" with no warranties, and confers no rights. |
|
Теги |
ax2009, recid, systemsequences |
|
Опции темы | Поиск в этой теме |
Опции просмотра | |
|