`Varchar Vector.setSafe` перезаписывает данные в следующей позицииJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 `Varchar Vector.setSafe` перезаписывает данные в следующей позиции

Сообщение Anonymous »

Я использую VarCharVector Apache-arrow.
Когда я пытаюсь установить значение, длина которого (скажем, размер = 4) больше установленного значения ранее (скажем, size = 3) он перезаписывает значение, присутствующее в следующей ячейке.
Тестовый код:

Код: Выделить всё

try (RootAllocator allocator = new RootAllocator();
VarCharVector vector = new VarCharVector("vector", allocator))
{
vector.setSafe(0, "abc".getBytes());
vector.setSafe(1, "def".getBytes());
vector.setSafe(2, "ghi".getBytes());
vector.setNull(3);
vector.setSafe(4, "jkl".getBytes());
vector.setValueCount(5);

vector.setSafe(1, "wzyz".getBytes());
System.out.println(vector);
}
Полученный вывод:

Код: Выделить всё

[abc, wzyz, hi, null, jkl]
ожидаемый вывод:

Код: Выделить всё

[abc, wzyz, ghi, null, jkl]
Я могу понять, почему и как это работает внутри. Но мой вопрос заключается в том, как поступить в этом случае.
Я также считаю, что это должно быть обработано в самой библиотеке, поскольку мы уже используем API setSafe.
Пожалуйста, помогите мне с этим делом.

Подробнее здесь: https://stackoverflow.com/questions/793 ... xt-postion
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»