AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 07.08.2009, 12:40   #1  
SHiSHok is offline
SHiSHok
Участник
Аватар для SHiSHok
Дети Юза
 
219 / 103 (4) +++++
Регистрация: 28.07.2005
Адрес: Донецк
размер 1 записи (строки)
как несложно посчитать сколько занимает 1 запись в таблице (максимальный размер и текущая выбранная)?
__________________
--- SHiSHok
Старый 07.08.2009, 13:13   #2  
ZVV is offline
ZVV
MCITP
MCP
Oracle
MCBMSS
 
1,006 / 246 (11) ++++++
Регистрация: 13.02.2004
Адрес: Минск
->
Цитата:
Сообщение от SHiSHok Посмотреть сообщение
как несложно посчитать сколько занимает 1 запись в таблице (максимальный размер и текущая выбранная)?
Вас интересует именно в Аксапте? думаю что никак...
Это зависит от СУБД, в сиквеле и в оракле ответ будет разный и искать надо там...

Для оракла могу написать вам запрос, если интересно..
__________________
Zhirenkov Vitaly
Старый 07.08.2009, 13:15   #3  
ZVV is offline
ZVV
MCITP
MCP
Oracle
MCBMSS
 
1,006 / 246 (11) ++++++
Регистрация: 13.02.2004
Адрес: Минск
->
Цитата:
Сообщение от ZVV Посмотреть сообщение
Вас интересует именно в Аксапте? думаю что никак...
ну не считая direct sql, конечно...
__________________
Zhirenkov Vitaly
Старый 07.08.2009, 13:23   #4  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Ну, приближенно можно посчитать с помощью метода fieldSize() на SysDictField:

X++:
static void Job2(Args _args)
{
    SysDictTable dictTable = SysDictTable::newName(tableStr(InventTable));
    SysDictField dictField;
    Counter      fieldCnt;
    int          recordSize;
    ;
    for (fieldCnt = 1; fieldCnt <= dictTable.fieldCnt(); fieldCnt++)
    {
        dictField = SysDictField::newName(dictTable.name(), dictTable.fieldName(dictTable.fieldCnt2Id(fieldCnt)));
        recordSize += dictField.fieldSize();
    }
    info(int2str(recordSize));
}
p.s. надо конечно учитывать все типы и array поля и т.д.
плюс служебную информацию заголовка сообщения при передаче по сети.
За это сообщение автора поблагодарили: aidsua (1).
Старый 07.08.2009, 13:27   #5  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Только что заметил, что на SysDictTable уже есть метод recordSize с реализацией, похожей на приведенную выше. Так что можно и им воспользоваться.
Старый 07.08.2009, 13:31   #6  
SRF is offline
SRF
Участник
MCBMSS
Axapta Retail User
 
375 / 562 (19) +++++++
Регистрация: 08.08.2007
Записей в блоге: 1
Цитата:
Сообщение от kashperuk Посмотреть сообщение
Ну, приближенно можно посчитать с помощью метода fieldSize() на SysDictField:

X++:
static void Job2(Args _args)
{
    SysDictTable dictTable = SysDictTable::newName(tableStr(InventTable));
    SysDictField dictField;
    Counter      fieldCnt;
    int          recordSize;
    ;
    for (fieldCnt = 1; fieldCnt <= dictTable.fieldCnt(); fieldCnt++)
    {
        dictField = SysDictField::newName(dictTable.name(), dictTable.fieldName(dictTable.fieldCnt2Id(fieldCnt)));
        recordSize += dictField.fieldSize();
    }
    info(int2str(recordSize));
}
p.s. надо конечно учитывать все типы и array поля и т.д.
плюс служебную информацию заголовка сообщения при передаче по сети.
Вообще конечно, есть аналогичный метод на SysDictTable - recordSize - делает все то, что в job'е, только вот сильно приближенный результат получается

Например, fieldSize считает, что поля типа Enum занимают 1 байт, а в реальности все 4 (DAX 4.0 MS SQL 2005)
X++:
        case Types::Enum:
            size = 1;
            break;
Для типа Date и DateTime - считает, что всего используется по 4 байта
X++:
        case Types::Date:
        case Types::DateTime:
        case Types::Integer:
            size = 4;
            break;
Но на самом деле там все 8 (в смысле на MS SQL Server)

Так, что я бы с осторожностью считал размер записи данным способом

Кстати, еще есть размер записи в таблице трассировки SQL операторов Администирование\Запросы\База данных\Журнал трассировки операторов SQL, вкладка Разное, только не понятно, насколько этот параметр соотвествует действительности и пронаблюдать его значение можно, только в случае есть SQL оператор попал в трассировку (но все таки этому параметру я доверяю больше, чем SysDictTable\recordSize)

P.S. Не видел предыдущего сообщения когда писал
__________________
Sergey Nefedov

Последний раз редактировалось SRF; 07.08.2009 в 13:39. Причина: p.s.
Старый 07.08.2009, 13:39   #7  
ZVV is offline
ZVV
MCITP
MCP
Oracle
MCBMSS
 
1,006 / 246 (11) ++++++
Регистрация: 13.02.2004
Адрес: Минск
Цитата:
Сообщение от SHiSHok Посмотреть сообщение
у меня ax3sp2 таких методов нет.
Импровизируйте

X++:
SysDictTable::newTableId(tableNum(InventTable));
__________________
Zhirenkov Vitaly
Старый 07.08.2009, 13:43   #8  
SHiSHok is offline
SHiSHok
Участник
Аватар для SHiSHok
Дети Юза
 
219 / 103 (4) +++++
Регистрация: 28.07.2005
Адрес: Донецк
Цитата:
Сообщение от ZVV Посмотреть сообщение
Импровизируйте
X++:
SysDictTable::newTableId(tableNum(InventTable));
поспешил. расчет есть.
__________________
--- SHiSHok
Старый 07.08.2009, 14:48   #9  
SHiSHok is offline
SHiSHok
Участник
Аватар для SHiSHok
Дети Юза
 
219 / 103 (4) +++++
Регистрация: 28.07.2005
Адрес: Донецк
решил так
каличный метод. у меня mssql2k, сделал следующее:

создал табличку (в ax)
CREATE TABLE [dbo].[TABLE2] (
[FSTR] [varchar] (10) COLLATE SQL_Ukrainian_CP1251_CI_AS NOT NULL ,
[FINT] [int] NOT NULL ,
[FREAL] [numeric](28, 12) NOT NULL ,
[FDATE] [datetime] NOT NULL ,
[FTIME] [int] NOT NULL ,
[FENUM] [int] NOT NULL ,
[FCON] [image] NULL ,
[DATAAREAID] [varchar] (3) COLLATE SQL_Ukrainian_CP1251_CI_AS NOT NULL ,
[RECID] [int] NOT NULL
)

+ пофиксил метод SysDictField.fieldSize() (по перекрестным ссылках используется только в отчетах о размере базы/компании):
X++:
int fieldSize()
{
    int size;
    switch (this.baseType())
    {
        case Types::DATETIME:
        case Types::DATE:
            size = 8;
            break;
//        case Types::DATE:
//        case Types::DATETIME:
        case Types::INTEGER:
            size = 4;
            break;
        case Types::BLOB:
        case Types::CONTAINER:
        case Types::VARSTRING:
            size = 2048; // 8192 div 4 (assumption: One out of 4 has data)
            break;
        case Types::REAL:
            size = 13; //20;
            break;
        case Types::ENUM:
            size = 4; //1;
            break;
        case Types::STRING:
        case Types::RSTRING:
            size = this.stringLen();
            break;
    }
    return size*this.arraySize();
}
дык оно просчитало вот такие поля:
X++:
TableId
RecId
sequenceNum
dataAreaId
createdTransactionId
createdBy
createdTime
createdDate
modifiedTransactionId
modifiedBy
modifiedTime
modifiedDate
fCon
fEnum
fTime
fDate
fReal
fInt
fStr
думаю для более реалистичной картины надо пофиксить sysDictTable.recordSize(). предлагаю так:
X++:
int recordSize()
{
    int size;
    int i;
    SysDictField sysDictField;

    for (i=this.fieldCnt(); i; i--)
    {
        SysDictField = new SysDictField(this.id(), this.fieldCnt2Id(i));
        if ( SysDictField.isSql() )
            size += SysDictField.fieldSize();
    }
    return size;
}
посчитало поля:
X++:
RecId
dataAreaId
fCon
fEnum
fTime
fDate
fReal
fInt
fStr
непонимаю только зачем "большие" поля типа container считать как 1/4 страницы.
__________________
--- SHiSHok

Последний раз редактировалось SHiSHok; 07.08.2009 в 14:54. Причина: дополнил
Старый 07.08.2009, 14:53   #10  
ZVV is offline
ZVV
MCITP
MCP
Oracle
MCBMSS
 
1,006 / 246 (11) ++++++
Регистрация: 13.02.2004
Адрес: Минск
->
Потому что это всё не более, чем гадания на хрустальном шарике...

Если нужно именно точная цифра, то выше я уже ответил...
__________________
Zhirenkov Vitaly
Старый 07.08.2009, 15:00   #11  
SHiSHok is offline
SHiSHok
Участник
Аватар для SHiSHok
Дети Юза
 
219 / 103 (4) +++++
Регистрация: 28.07.2005
Адрес: Донецк
по крайней мере если нет больших типов можно получить точный расчет.
__________________
--- SHiSHok
Старый 07.08.2009, 15:04   #12  
ZVV is offline
ZVV
MCITP
MCP
Oracle
MCBMSS
 
1,006 / 246 (11) ++++++
Регистрация: 13.02.2004
Адрес: Минск
->
Цитата:
Сообщение от SHiSHok Посмотреть сообщение
по крайней мере если нет больших типов можно получить точный расчет.
Точный расчёт чего? Максимального размера - да, можно...

Точного размера текущей записи в БД?

То что цифры (в оракле по крайней мере) могут занимать разное кол-во байт в БД в зависимоти от размера, вы учитываете?
То что БД может быть Юникодная вы учитываете?
...
__________________
Zhirenkov Vitaly
Старый 07.08.2009, 15:20   #13  
SHiSHok is offline
SHiSHok
Участник
Аватар для SHiSHok
Дети Юза
 
219 / 103 (4) +++++
Регистрация: 28.07.2005
Адрес: Донецк
Цитата:
Сообщение от ZVV Посмотреть сообщение
Точный расчёт чего? Максимального размера - да, можно...
да (с оговоркой про большие поля)

судя по всему в ax нет точного расчета размера записи.
остается сиквел ковырять.
__________________
--- SHiSHok
Старый 07.08.2009, 17:38   #14  
Bober is offline
Bober
Участник
 
311 / 104 (4) +++++
Регистрация: 29.05.2007
Цитата:
Сообщение от SHiSHok Посмотреть сообщение
как несложно посчитать сколько занимает 1 запись в таблице (максимальный размер и текущая выбранная)?
Давно хотелось спросить: вопрос продиктован чисто академическим интересом или практическим ? если практическим - то каким именно? (хотите спрогнозировать рост базы на Х лет вперед при определенной интенстивности работы юзеров ? )
Старый 10.08.2009, 09:58   #15  
SHiSHok is offline
SHiSHok
Участник
Аватар для SHiSHok
Дети Юза
 
219 / 103 (4) +++++
Регистрация: 28.07.2005
Адрес: Донецк
Цитата:
Сообщение от Bober Посмотреть сообщение
Давно хотелось спросить: вопрос продиктован чисто академическим интересом или практическим ? если практическим - то каким именно? (хотите спрогнозировать рост базы на Х лет вперед при определенной интенстивности работы юзеров ? )
в mssql2k: Bytes per row = 8060, При добавлении "больших" (да и не только) полей хотелось знать насколько близок предел.
А усредненный прогноз роста базы я делаю по статистике роста бекапов сиквела.
__________________
--- SHiSHok
Старый 10.08.2009, 18:02   #16  
SHiSHok is offline
SHiSHok
Участник
Аватар для SHiSHok
Дети Юза
 
219 / 103 (4) +++++
Регистрация: 28.07.2005
Адрес: Донецк
btw, для статистической информации (min, max, avg) размер записи в mssql2k подойдет dbcc showcontig
__________________
--- SHiSHok
Теги
sql, запись

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Цветные строки в Grid Sergo DAX: База знаний и проекты 14 19.04.2012 10:02
AX4: Кнопка "Сценарий" в паспорте записи Den Ram DAX: Функционал 2 19.04.2007 13:53
При создании строки в закупке статус строки становится "Отменено" AlexUnik DAX: Функционал 4 27.09.2004 16:05
Автоматическое увеличение значения поля при создании новой записи. sguryev DAX: Программирование 3 06.02.2003 14:00
Строки журналов Андре DAX: Программирование 14 08.08.2002 10:02

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 10:15.