Firebird: Using global variable

2019-07-07 07:53发布

I would like to assign a value to a variable which is used in an sql code in firebird. The MySQL-Code would be:

SET @x = 1;
SELECT @x;

What is the correspondent Firebird-Code?

Thanks for help.

标签: sql firebird
2条回答
Bombasti
2楼-- · 2019-07-07 08:30

I'm no expert in Firebird, but I believe it would be something like this...

set term ^ ;

EXECUTE BLOCK
AS
DECLARE VARIABLE x int;
BEGIN
  x = 1; 
  --do whatever you want with x, there's no such thing 
  --as to select the variable value to print it
END
^

set term ; ^
查看更多
我只想做你的唯一
3楼-- · 2019-07-07 08:44

To define a user-defined session-specific variable in Firebird you can use rdb$set_context.

The correspondent Firbird-code for your MySql-example would be:

select rdb$set_context('USER_SESSION', 'x', 1) from rdb$database
select rdb$get_context('USER_SESSION', 'x') from rdb$database

Notes:

1.) Be aware that variable names are case-sensitive.

2.) Internally variable values are stored with datatype VARCHAR(255) and thus casted to VARCHAR(255)!!

3.) The maximum number of variables is 1000.

4.) You don't need to refer to rdb$database:

select rdb$get_context('USER_SESSION', 'x') from some_table_name

would work as well.

查看更多
登录 后发表回答