Advertisement
Help Keep Boards Alive. Support us by going ad free today. See here: https://subscriptions.boards.ie/.
If we do not hit our goal we will be forced to close the site.

Current status: https://keepboardsalive.com/

Annual subs are best for most impact. If you are still undecided on going Ad Free - you can also donate using the Paypal Donate option. All contribution helps. Thank you.
https://www.boards.ie/group/1878-subscribers-forum

Private Group for paid up members of Boards.ie. Join the club.

SQL Query Help

  • 25-04-2007 09:46AM
    #1
    Registered Users, Registered Users 2 Posts: 500 ✭✭✭


    making it as simple as possible - i have a table with 2 colums name and date.

    what i want my query to do is select all values from this and anywhere the date is = '' // ie: empty string then output "no". anywhere its not i output "yes"
    Name Date
    Mark 10-10-2006
    John
    Paul 10-10-2006
    Sean
    QUERY RETURNS
    Mark yes
    John no
    paul yes
    sean no

    heres what im trying but to no avial.

    declare @xxx varchar(20)
    SET @xxx = 'yes'
    SELECT Name, @xxx, Date, Date FROM TABLE
    WHERE Date = ''
    SET @xxx = 'no'

    Hope you can help?


Comments

  • Moderators, Politics Moderators, Paid Member Posts: 44,265 Mod ✭✭✭✭Seth Brundle


    is this for MSSQL?
    is the date null?
    Why are you selecting the Date field twice?

    Help Keep Boards Alive. Support us by going ad free today. See here: https://subscriptions.boards.ie/ .



  • Registered Users, Registered Users 2 Posts: 500 ✭✭✭warrenaldo


    yes its for MSSQL - not selecting the date twice. just a typo in my sample code.
    i think i can do it via a union in some way.


  • Moderators, Politics Moderators, Paid Member Posts: 44,265 Mod ✭✭✭✭Seth Brundle


    try
    SELECT 
    [Name], 
    (CASE WHEN [Date] ISNULL THEN 'no' ELSE 'yes') as [Dates]
    FROM TABLE
    
    or
    SELECT 
    [Name], 
    (CASE WHEN [Date] ='' THEN 'no' ELSE 'yes') as [Dates]
    FROM TABLE
    

    Help Keep Boards Alive. Support us by going ad free today. See here: https://subscriptions.boards.ie/ .



  • Registered Users, Registered Users 2 Posts: 68,173 ✭✭✭✭seamus


    It may be worth building a simple function to do the processing for you, e.g.
    CREATE FUNCTION containsDate(@dateCol varchar(10))
    RETURNS varchar(3)
    AS
    BEGIN
    declare @Return varchar(3)
    IF @dateCol = ''
        set @Return = 'no'
    ELSE 
        set @Return = 'yes'
    
    RETURN @Return
    END
    

    Then you just call
    SELECT Name, containsDate(Date) FROM TABLE

    ...in theory.


  • Registered Users, Registered Users 2 Posts: 500 ✭✭✭warrenaldo


    great stuff.
    SELECT 
    [Name], 
    (CASE WHEN [Date] ISNULL THEN 'no' ELSE 'yes') end [Dates] 
    FROM TABLE
    
    end instead of as.
    works like a dream - nice and fast too.
    cheers


  • Advertisement
  • Moderators, Politics Moderators, Paid Member Posts: 44,265 Mod ✭✭✭✭Seth Brundle


    It should have been more like
    SELECT 
    [Name], 
    (CASE WHEN [Date] ISNULL THEN 'no' ELSE 'yes' END) as [Dates]
    FROM TABLE
    

    Help Keep Boards Alive. Support us by going ad free today. See here: https://subscriptions.boards.ie/ .



  • Registered Users, Registered Users 2 Posts: 6,475 ✭✭✭MOH


    warrenaldo wrote:
    yes its for MSSQL - not selecting the date twice. just a typo in my sample code.
    i think i can do it via a union in some way.
    You could have done it with a union with
    SELECT name, 'Yes', date
    FROM table
    WHERE date = ''
    UNION
    SELECT name, 'No', date
    FROM table
    WHERE date <> ''
    


Advertisement