Массивы с переменной длиной элементов

С переменной длиной элементов массива могут быть только строковые и байтовые массивы.

Объявление этих массивов возможно двумя способами: в стиле СУБД ЛИНТЕР или в стиле СУБД Ingres. Смешение стилей в одном исходном тексте модуля основного языка не допускается.

1 способ (в стиле СУБД ЛИНТЕР)

<массив с переменной длиной элементов>::=
{VARCHAR | VARBIT}
<имя> <размер1> [<размер2>] <длина элемента>

2 способ (в стиле СУБД Ingres)

{[VARCHAR]|VARBIT} struct
{
short length;
char text<длина элемента>;
} <имя><размер1> [<размер2>];

<имя>::=переменная основного языка
<размер1>::='['<значение>']'
<размер2>::='['<значение>']'
<длина элемента>::='['<значение>']'
<значение>::= целое положительное число
Описание
  1. <Длина элемента> задает максимальный размер элемента массива.

  2. VARCHAR, VARBIT – тип данных элемента массива. Объявление этих массивов возможно двумя способами: в стиле СУБД ЛИНТЕР или в стиле СУБД Ingres. Смешение стилей в одном исходном тексте модуля основного языка не допускается.

  3. В случае объявления в стиле СУБД ЛИНТЕР массивы транслируются в виде:

    • VARCHAR[n]][m]:

      struct
       { short len;
        char arr[m];
       } <имя>[n];
    • VARBIT [n][m]:

      struct
       { short len;
       unsigned char arr[m];
       } <имя>[n];
  4. В случае объявления в стиле СУБД Ingres массивы транслируются в виде:

    • VARCHAR[n]][m]:

      struct
       { short length;
       char text[m];
       }<имя>[n]
    • VARBIT [n][m]:

      struct
       { short length;
       unsigned char text[m];
       }<имя>[n]