Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Sybase With Clause using a declare

Posted on 2013-06-18
7
Medium Priority
?
3,174 Views
Last Modified: 2013-06-25
Hi,

We are using Sybase anywhere 11 and I have a query that uses a with clause e.g.

WITH Table1 AS
(
SELECT * FROM TABLE2 WHERE Date = '2013-06-18'
)

Open in new window


However, what I would like to do is declare a variable, e.g. @Date to take place of the fixed value. I cannot seem to get this to work with Sybase.
0
Comment
Question by:spen_lang
  • 5
  • 2
7 Comments
 
LVL 49

Expert Comment

by:PortletPaul
ID: 39255693
mmm, not something I know a lot about, but documentation suggests a slightly different syntax to TSQL.

CREATE VARIABLE identifier data-type
http://dcx.sybase.com/index.html#1101/en/dbreference_en11/create-variable-statement.html

The SET statement assigns a new value to a variable. The variable must have been previously created using a CREATE VARIABLE statement or DECLARE statement, or it must be an OUTPUT parameter for a procedure. The variable name can optionally use the Transact-SQL convention of an @ sign preceding the name. For example:

SET @localvar = 42

A variable can be used in a SQL statement anywhere a column name is allowed. If a column name exists with the same name as the variable, the variable value is used.
http://dcx.sybase.com/index.html#1101/en/dbreference_en11/set-statement.html

so without an ability to trial it, it might look like:

CREATE VARIABLE myDate datetime
set @myDate = '2013-06-19'
; with table1 as (
                           select * from whatever where adate > @myDate
                         )
select
*
from table1;

but 99% of the above is an assumption I regret to say
0
 

Author Comment

by:spen_lang
ID: 39255699
Thanks for your response.

The problem I have is that I know the correct syntax for DECLARE and WITH but I am unable to combine the two in one statement.

I can DECLARE a variable in a statement without a WITH and vice versa...
0
 
LVL 49

Expert Comment

by:PortletPaul
ID: 39255711
documentation suggests declare is for use with BEGIN - END

have you tried CREATE VARIABLE

I too would have started with declare - but that appears to be different in Anywhere
0
Concerto Cloud for Software Providers & ISVs

Can Concerto Cloud Services help you focus on evolving your application offerings, while delivering the best cloud experience to your customers? From DevOps to revenue models and customer support, the answer is yes!

Learn how Concerto can help you.

 

Author Comment

by:spen_lang
ID: 39255717
The CREATE VARIABLE worked but the problem is that it is only dropped when the connection is dropped, the SQL will be ran from inside an application (report) and I think this may cause issues.
0
 
LVL 49

Expert Comment

by:PortletPaul
ID: 39255734
You can explicitly drop the created variable:
DROP VARIABLE  [ IF EXISTS ] identifier
Remarks
The DROP VARIABLE statement eliminates a SQL variable that was previously created using the CREATE VARIABLE statement. Variables are automatically eliminated when the database connection is released. Variables are often used for large objects, so eliminating them after use or setting them to NULL can free up significant resources (primarily disk space).

Use the IF EXISTS clause if you do not want an error returned when the DROP statement attempts to remove a database object that does not exist.
http://dcx.sybase.com/index.html#1101/en/dbreference_en11/drop-variable-statement.html
0
 
LVL 49

Accepted Solution

by:
PortletPaul earned 2000 total points
ID: 39255738
also noteworthy:
Variables belong to the current connection, and disappear when you disconnect from the database or when you use the DROP VARIABLE statement. Variables are not visible to other connections.
create variable, url provided above
0
 
LVL 49

Expert Comment

by:PortletPaul
ID: 39274007
thank you! I trust you were able to get the variables to work.

Cheers, Paul
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

I'm trying, I really am. But I've seen so many wrong approaches involving date(time) boundaries I despair about my inability to explain it. I've seen quite a few recently that define a non-leap year as 364 days, or 366 days and the list goes on. …
This month, Experts Exchange sat down with resident SQL expert, Jim Horn, for an in-depth look into the makings of a successful career in SQL.
Using examples as well as descriptions, and references to Books Online, show the documentation available for date manipulation functions and by using a select few of these functions, show how date based data can be manipulated with these functions.
This videos aims to give the viewer a basic demonstration of how a user can query current session information by using the SYS_CONTEXT function

782 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question