Simple Oracle variable SQL Assignment
Asked Answered
I

5

10

Despite having spent an hour researching I can't seem to figure out how to correctly define a variable and then use it in your SQL.

This is what I have so far produced:

DECLARE startDate DATE := to_date('03/11/2011', 'dd/mm/yyyy');

of which I get the reply:

ORA-06550: line 1, column 63: PLS-00103: Encountered the symbol "end-of-file" when expecting one of the following:

begin function package pragma procedure subtype type use form current cursor

Details: DECLARE startDate DATE := to_date('03/11/2011', 'dd/mm/yyyy'); Error at line 1 ORA-06550: line 1, column 63: PLS-00103: Encountered the symbol "end-of-file" when expecting one of the following:

begin function package pragma procedure subtype type use form current cursor

I'd love to find out how to do such a simple task!

Impertinent answered 7/11, 2011 at 17:6 Comment(1)
Variables are a client construct. You need to tell us what client you are using.Eduino
E
17

Your variable declaration is correct.

The DECLARE keyword is used to define variables scoped in a PL/SQL block (whose body is delimited by BEGIN and END;). How do you want to use this variable?

The following PL/SQL works fine for me:

DECLARE 
    startDate DATE := to_date('03/11/2011', 'dd/mm/yyyy');
    reccount INTEGER;
BEGIN
    SELECT count(*) INTO reccount 
        FROM my_table tab 
        WHERE tab.somedate < startDate;
    dbms_output.put_line(reccount);
END;

You can also use the DEFINE statement to use simple string substitution variables. They are suitable for a client like SQL/PLUS or TOAD.

DEFINE start_date = "to_date('03/11/2011', 'dd/mm/yyyy')"
SELECT COUNT(*) from my_table tab where tab.some_date < &start_date;
Enravish answered 7/11, 2011 at 17:10 Comment(4)
So is there no way to do it succinctly like in MS SQL where it's a simple declare @varible set @variable? I'd like to later use the variable in a WHERE clause, how would I do that? How would I also print the variable to screen?Impertinent
I'm not familiar with MS SQL, but if you're referring to some kind of global variable, it's possible to define a variable in a package, thus making it visible to all the package's members, even though global variables are something you'll probably want to avoid. You can print the variable to screen using dbms_output.put_line.Impressure
Not a global variable - just a normal variable that I can assign and then use later onImpertinent
I've been about to post this before but wasn't sure this is what you wanted. You can also use the DEFINE statement to interpolate simple string substitution variables. See my updated on the answer for an example.Impressure
P
7

To accomplish what you're attempting in Toad, you don't need to declare the variable at all. Simply include your variable prefaced with a colon and Toad will prompt you for the variable's value when you execute the query. For example:

select * from all_tables where owner = :this_is_a_variable;

If this doesn't work initially, right-click anywhere in the editor and make sure "Prompt for Substitution Variables" is checked.

If you really want to do it similarly to the way SQL Server handles variables (or you want to be able to do the same thing in SQL*Plus), you can write it as follows:

var this_is_a_variable varchar2(30); 

exec :this_is_a_variable := 'YOUR_SCHEMA_NAME';

print this_is_a_variable;

select * from all_tables where owner = :this_is_a_variable;

However, to make this work in Toad, you'll need to run it through "Execute as script", rather than the typical "Execute statement" command.

Podgy answered 7/11, 2011 at 18:40 Comment(0)
I
4

Take in mind that Oracle's PL/SQL is not SQL.

PL/SQL is a procedural language. SQL is not procedural, but you can define "variables" the user can enter via the "&var" syntax (see http://www.orafaq.com/node/515).

Industrialism answered 7/11, 2011 at 18:29 Comment(0)
J
4

This is an old post, but in case anyone stumbles on this (as I just did), you can handle this with a CTE:

with params as (
      select date '2011-11-03' as startdate
      from dual
     )
select . . .
from params cross join
     . . .

Almost the same syntax works in SQL Server (minus the date-specific stuff and from dual).

Johnsten answered 16/10, 2015 at 20:40 Comment(0)
N
0

Solution

DEF  startDate = to_date('03/11/2011', 'dd/mm/yyyy');
Select &startDate from dual;
Nadabas answered 21/4, 2015 at 15:16 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.