Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Создание процедуры в firebird
Форум на CrossPlatform.RU > Библиотеки > Qt > Qt Разработка баз данных
berserk
Всем привет!

Кто нибудь знает возможно ли создание хранимой процедуры в firebird программно?
С консоли приходится заменять символ конца строки. "SET TERM".
Весь гугл перерыл, не могу найти как программно создать процедуру(((
Iron Bug
а что, простым выполнением запроса с командой создания она не создаётся? вроде почти все базы данных так и работали всегда.
Гость_berserk_*
Цитата(berserk @ 22.5.2014, 23:32) *
Всем привет!

Кто нибудь знает возможно ли создание хранимой процедуры в firebird программно?
С консоли приходится заменять символ конца строки. "SET TERM".
Весь гугл перерыл, не могу найти как программно создать процедуру(((


имеется ввиду qyery,exec("CREATE PROCEDURE.......") ?

у меня не получилось. Всё дело видимо в том что конец строки внутки процедуры и в самом SQL является символ ";". Любая "IDE" делает примерно так

SET TERM ^;

CREATE PROCEDURE name
( input_parameter_name < datatype>, ... )
RETURNS
( output_parameter_name < datatype>, ... )
AS
DECLARE VARIABLE variable_name < datatype>;
BEGIN
  /* write your code here */
END^

SET TERM; ^


По крайней мере в firebird так точно.
Iron Bug
попробуй set term выполнить отдельной командой, но в одной транзакции.
berserk
Цитата(Iron Bug @ 23.5.2014, 20:35) *
попробуй set term выполнить отдельной командой, но в одной транзакции.


пробовал так...
QSqlDatabase db = QSqlDatabase::addDatabase("QIBASE");
    db.setHostName("127.0.0.1");
    db.setDatabaseName("123");
    db.setUserName("SYSDBA");
    db.setPassword("masterkey");
    if (db.open())
    {
        qDebug() << "Ok" << endl;
        QSqlQuery query;
        db.transaction();
        query.exec("SET TERM ^;");
        query.exec("CREATE PROCEDURE proc AS DECLARE VARIABLE abc integer; BEGIN abc = 5; END^");
        query.exec("SET TERM; ^");
        qDebug() << query.lastError().text() << endl;
        db.commit();
    }
    else
    {
        qDebug() << "Error" << endl;
    }


на консоле то же самое что и если в одном запросе выполнять(((
"Dynamic SQL Error - SQL error code = -104 - Token unknown - line 1, column 5 - TERM Could not prepare statement"
Iron Bug
а нужен ли вообще тот терминатор при выполнении из запроса? в консоли он просто обозначает конец процедуры. а в запросе из интерфейса точка с запятой не является концом запроса.
убери нафиг и установку, и сам знак терминатора.
Гость_berserk_*
Цитата(Iron Bug @ 24.5.2014, 22:00) *
а нужен ли вообще тот терминатор при выполнении из запроса? в консоли он просто обозначает конец процедуры. а в запросе из интерфейса точка с запятой не является концом запроса.
убери нафиг и установку, и сам знак терминатора.


Без него тоже не работает... Всё тему можно закрыть. Перешёл на Postgresql.
Алексей1153
без всяких терминаторов создавал и менял

" create procedure "
"alter procedure "

прекрасно работает
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Форум IP.Board © 2001-2024 IPS, Inc.