powered by simpleCommunicator - 2.0.53     © 2025 Programmizd 02
Форумы / IBM DB2, WebSphere, IMS, U2 [игнор отключен] [закрыт для гостей] / Dynamic sql + C stored procedure + os/390
4 сообщений из 4, страница 1 из 1
Dynamic sql + C stored procedure + os/390
    #32873187
Фотография Nik V. Polonski
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Доброго всем здоровья.
Занимаюсь портированием ряда хранимых процедур на C w2k -> os/390. Граблей отгреб уже по самые нехочу. Вот очередные.
Готовлю запрос:
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
....
  char hQSTR??( 500 ??);
....

  sprintf( hQSTR, "...." );
....

  EXEC SQL PREPARE QUERY FROM :hQSTR;
....
Вроде - все как в документации. Под win работает великолепно, под 390 при трансляции ругается в лог:

DSNH080I E DSNHSM3D LINE 213 COL 32 STRING VARIABLE "hQSTR" IS NOT "VARCHAR" TYPE
PREPARE QUERY FROM:hQSTR
DSNH050I I DSNHMAIN WARNINGS HAVE BEEN SUPPRESSED DUE TO LACK OF TABLE DECLARATIONS
SOURCE STATISTICS
SOURCE LINES READ: 249
NUMBER OF SYMBOLS: 20
SYMBOL TABLE BYTES EXCLUDING ATTRIBUTES: 2096
THERE WERE 2 MESSAGES FOR THIS PROGRAM.
THERE WERE 0 MESSAGES SUPPRESSED BY THE FLAG OPTION.
153248 BYTES OF STORAGE WERE USED BY THE PRECOMPILER.
RETURN CODE IS 8

char* - тоже не помогает. Пока ничто не приложу, как быть. С динамики на embedded переписывать - желания мало, да и сроки уже жмут...
Благодарю за внимание.
...
Рейтинг: 0 / 0
Dynamic sql + C stored procedure + os/390
    #32873305
Фотография NewYear
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
завтра напишу как. точно занаю ответ, просто убегаю уже.
...
Рейтинг: 0 / 0
Dynamic sql + C stored procedure + os/390
    #32873318
Фотография NewYear
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
впрочем вот
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
EXEC SQL BEGIN DECLARE SECTION;
    struct VARCHAR {
      short len;
      char s[ 1024 ];
    } stmt;
EXEC SQL END DECLARE SECTION;

sprintf(stmt.s,...);
s.len = strlen(stmt.s);


EXEC SQL EXECUTE IMMEDIATE :stmt;

...
Рейтинг: 0 / 0
Dynamic sql + C stored procedure + os/390
    #32874059
Фотография Nik V. Polonski
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Работает, спасибо большое. Нашел, где про это написано - в Application Development Guide - Supported SQL Data Types in C and C++. Почему бы об этом не упомянуть, например, в самой SQL Reference - EXECUTE IMMEDIATE...
...
Рейтинг: 0 / 0
4 сообщений из 4, страница 1 из 1
Форумы / IBM DB2, WebSphere, IMS, U2 [игнор отключен] [закрыт для гостей] / Dynamic sql + C stored procedure + os/390
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]