Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
5 / 5 / 2
Регистрация: 06.04.2011
Сообщений: 290
1
Oracle

ODAC -> Как записать короткий массив char*?

25.11.2015, 11:51. Показов 682. Ответов 8
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
В таблице под Ораклом есть поле, описанное как VARCHAR2(4000 Byte). В это поле мне нужно передать короткий байтовый массив, например, char arr[300].
Для этого используется компонента (хранимая процедура) ODAC класса TOraStoredProc, где соответствующий параметр описан как VARCHAR2.

1. Какой тип этого параметра мне надо указать в TOraStoredProc?
2. Как char arr[300] засунуть в этот параметр?

В целом, проблема такая: как записать в поле таблицы короткий байтовый массив без использования BLOBов? Видимо, как-то просто, но никак не получается.
Может быть, кто поможет?
Спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.11.2015, 11:51
Ответы с готовыми решениями:

Как char записать в массив?
пример кода for (int i = 0; i < N; i++) { char str...

Как записать char массив в конструкторе
Подскажите, как записать char масив в кострукторе #include <iostream> #include <string.h> ...

Как прочитать строку из едита и записать ее в массив char
Как прочитать строку из едита и записать ее в массив char?

Как поток данных с последовательного порта записать в массив типа char
Как реализовать запись символов приходящих с последовательного порта в массив char? Например при...

8
Почетный модератор
8784 / 2537 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
25.11.2015, 12:54 2
vlad2, вообще в оракле выделяется ровно столько места, сколько нужно данным, а не сколько у вас указано в размерности поля...
0
5 / 5 / 2
Регистрация: 06.04.2011
Сообщений: 290
25.11.2015, 13:46  [ТС] 3
Цитата Сообщение от Lord_Voodoo Посмотреть сообщение
vlad2, вообще в оракле выделяется ровно столько места, сколько нужно данным, а не сколько у вас указано в размерности поля...
Ну хорошо, размер массива у меня есть. Вопрос в том, как его засунуть в параметр.
0
4217 / 3058 / 583
Регистрация: 21.01.2011
Сообщений: 13,205
25.11.2015, 15:31 4
Цитата Сообщение от vlad2 Посмотреть сообщение
Вопрос в том, как его засунуть в параметр
Например, создать из массива единую строку
0
Почетный модератор
8784 / 2537 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
25.11.2015, 15:44 5
vlad2, если я не ошибаюсь, то BLOB записывались с помощью потоков, посмотрите на форуме, я даже рабочий пример выкладывал, а если найду у себя, то сам выложу...

Добавлено через 5 минут
Запись файла в BLOB поле SQL запросом

Думаю, с ODAC такой фокус тоже пройдет:

C++
1
2
3
4
5
6
7
8
ADOTable1->Insert(); 
TMemoryStream *M = new TMemoryStream(); 
M->LoadFromFile("h:\\my_file.doc"); 
TStream *B = ADOTable1->CreateBlobStream(ADOTable1->FieldByName("My_Field"),bmWrite); 
B->CopyFrom(M,M->Size); 
delete B; 
ADOTable1->Post(); 
delete M;
потому что я с PgDac такое проделывал, но не могу найти рабочего кода...
0
5 / 5 / 2
Регистрация: 06.04.2011
Сообщений: 290
25.11.2015, 16:34  [ТС] 6
Цитата Сообщение от Lord_Voodoo Посмотреть сообщение
BLOB записывались с помощью потоков
С блобом вопросов нет, проблема в том, как обойтись без него (см. начальный пост).
0
Почетный модератор
8784 / 2537 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
25.11.2015, 17:46 7
а какая разница между картинкой и набором байтов? по-моему, никакой, если у тебя есть готовый кусок кода, причем поле в таблице уже определено, то просто подложи данные да и все...
0
5 / 5 / 2
Регистрация: 06.04.2011
Сообщений: 290
25.11.2015, 19:46  [ТС] 8
Цитата Сообщение от Lord_Voodoo Посмотреть сообщение
просто подложи данные да и все
Собственно, и спрашиваю, как это сделать, чтобы потом получить те же самые байты один в один.

Добавлено через 1 час 16 минут
Спасибо, вопрос решили на сервере.
0
Почетный модератор
8784 / 2537 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
26.11.2015, 10:31 9
vlad2, небось заменой типа данных у поля?
0
26.11.2015, 10:31
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.11.2015, 10:31
Помогаю со студенческими работами здесь

Записать число типа int в массив char -ов так, как оно представляется в памяти
Здравствуйте, моя цель - записать переменную какого-либо типа в массив char-ов (строку) так, как...

Записать один массив Char в другой
Не могу запихнуть один чаровский массив в другой, помогите. char *operat={"printf",...

Записать одномерный char* массив в двумерный в качестве строки
Собсна вот краткий алгоритм действий для решения задачи: считать строки из файла в переменную ...

Массив типа char записать в одну ячейку другого массива
Добрый день, есть массив типа char. В нем в одной ячейке элемент 'a', в другой 'b'. Я создать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Как запретить подсветку выделенного текста с помощью CSS
InfoMaster 20.01.2025
Подсветка текста при выделении является стандартным поведением браузера, которое не всегда соответствует дизайнерским решениям или функциональным требованиям веб-приложения. Выделение текста может. . .
Как выполнить другую программу или системную команду из Python
InfoMaster 20.01.2025
Python предоставляет мощные инструменты для выполнения системных команд и управления внешними процессами, что делает его идеальным выбором для автоматизации различных задач системного. . .
Как узнать директорию bash-скрипта из самого bash-скрипта
InfoMaster 20.01.2025
При разработке bash-скриптов одной из важных задач является определение директории, в которой находится исполняемый скрипт. Это критически важно для корректной работы с файлами, загрузки конфигураций. . .
В чем разница между let и var в JavaScript
InfoMaster 20.01.2025
JavaScript прошел длинный путь эволюции с момента своего создания в 1995 году. Одним из важнейших аспектов развития языка стало совершенствование механизмов объявления и управления переменными. . . .
Эффективная работа со строками в Go
InfoMaster 20.01.2025
Язык программирования Go предлагает уникальный подход к работе со строками, который существенно отличается от многих других языков программирования. В Go строки представляют собой неизменяемые. . .
Как проверить, что отображение (map) содержит ключ в Go
InfoMaster 20.01.2025
Отображения (maps) в языке программирования Go представляют собой мощные структуры данных, которые позволяют хранить пары ключ-значение и обеспечивают быстрый доступ к данным по уникальным. . .
Как организовать домашнее хранилище фильмов с общим доступом для всей семьи
InfoMaster 20.01.2025
Преимущества домашнего медиасервера В современном мире, где цифровой контент стал неотъемлемой частью нашей жизни, организация домашнего медиасервера становится все более актуальной задачей. . . .
Перспективы развития жестких дисков: есть ли у них будущее?
InfoMaster 20.01.2025
История и эволюция жестких дисков История развития жестких дисков начинается в 1956 году, когда компания IBM представила первое устройство для хранения данных на магнитных пластинах - IBM 350. . .
Распознавание изображений (компьютерное зрение) на C++
InfoMaster 20.01.2025
Введение в компьютерное зрение и основы работы с изображениями Компьютерное зрение представляет собой одну из наиболее динамично развивающихся областей информационных технологий, позволяющую. . .
Какой язык программировани­я лучший для разработки нейронных сетей
InfoMaster 20.01.2025
В современном мире технологий искусственные нейронные сети становятся неотъемлемой частью множества инновационных решений, от распознавания речи до автоматического управления транспортными. . .
Как подключить JavaScript файл в другом JavaScript файле
InfoMaster 20.01.2025
В современной веб-разработке организация кодовой базы играет ключевую роль в создании масштабируемых и поддерживаемых приложений. Модульность и правильное структурирование кода стали неотъемлемыми. . .
Как откатить изменения в исходниках, не внесенные в Git
InfoMaster 20.01.2025
При работе с системой контроля версий Git разработчики часто сталкиваются с необходимостью отменить внесенные изменения в исходном коде. Особенно актуальной становится ситуация, когда изменения еще. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru