Jump to content

AS expression contains an IF statement - not working


dmirsch

Recommended Posts

I am a beginner to PHP/MySQL and have just reformatted our website to this on a UNIX platform. Usually when I use an ACCESS database to create a SQL statement I can figure out how to fix a syntax error in MySQL. This time I am stumped. Here is my ACCESS sql statement:

SELECT DISTINCT venues.VenueCode, venues.VenueName, IIf([startDateTime]>=Now()-1,True,False) AS ShowVenue
FROM venues LEFT JOIN Performance ON venues.VenueCode=Performance.VenueCode
WHERE (((venues.VenueCode)<>"VV") AND ((IIf([startDateTime]>=Now()-1,True,False))=True))
ORDER BY venues.VenueName;

 

When I look up how to format IF statements in MySQL, I realize that that is a portion of the query I will have to change, but I'm not exactly sure how to do so and still retain term "ShowVenue." Also I know how to clean up my WHERE clause and have ended up with the following:

SELECT DISTINCT venues.VenueCode, venues.VenueName, IF(([Performance.startDateTime]>=Now() - INTERVAL 1 DAY),"True","False") AS ShowVenue
FROM venues LEFT JOIN Performance ON venues.VenueCode = Performance.VenueCode
WHERE venues.VenueCode!="VV" AND ShowVenue == "True"
ORDER BY venues.VenueName

 

Please help a struggling beginner  ::)

Link to comment
Share on other sites

For more information, I am using MySQL 5.0, and the following is the error message I receive:

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '[Performance.startDateTime]>=Now() - INTERVAL 1 DAY),"True","False") AS ShowVenu' at line 1
Link to comment
Share on other sites

The problem lies here:

IF(([Performance.startDateTime]>=Now() - INTERVAL 1 DAY),"True","False")

 

It's converting > and " to html entities which makes me think there's a problem with how you're having that condition used in the actual query. I'm confused about some of the stuff you're using in the query as well. "[Performance.startDateTime]>=Now() - INTERVAL 1 DAY". It looks like you're trying to use .asp in a query? That's not going to work out.

 

IF(([Performance.startDateTime]>=Now() - INTERVAL 1 DAY),"True","False")

Link to comment
Share on other sites

Basically what I have is two different tables within my database (Performance) and (venues). One venueName could have multiple Performance.startDateTime. What I would like is to create a dropdown menu where IF there is at least ONE Performance.startDateTime in a venueName, then list the venueName in my dropdown menu. Currently, my dropdown menu contains a venueName for EVERY Performance.startDateTime --> hence multiple listings of the same venueName.

 

You can see this in my work-in-progress webpage at http://www.myalaskacenter.com/calendars/calendarSample.php. This is not a final document, so not much works at this time.

 

Anyway, when I did it in ACCESS it allowed me to make an expression called ShowVenue that was a TRUE/FALSE value and then in my WHERE clause I could display all the cases where ShowVenue was TRUE. Since it was a DISTINCT selection, then I had a clean listing for my dropdown menu.

 

If you or someone else could lead me in the right direction to accomplish this in MySQL, I would be very grateful. I have a feeling that when the answer is posted I will be hitting my forehead.

Link to comment
Share on other sites

OK, so now I have

SELECT DISTINCT venues.VenueCode, venues.VenueName, IF(Performance.startDateTime >= Now()),'True','False') AS ShowVenue
FROM venues LEFT JOIN Performance ON venues.VenueCode = Performance.VenueCode
WHERE venues.VenueCode!="VV" AND ShowVenue == 'True'
ORDER BY venues.VenueName

and it still does not work.

 

Any ideas?

Link to comment
Share on other sites

yes, it's the same error:

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '),'True','False') AS ShowVenue FROM venues LEFT JOIN Performance ON venues.Venu' at line 1
Link to comment
Share on other sites

You don't really need the calculation in the SELECT clause. And you don't need the LEFT Join (as that will return Venues that have NO performance records -- although the WHERE clause is going to remove them). I think the query below will work, I don't have a system to test it on here.

 

SELECT DISTINCT venues.VenueCode, venues.VenueName
FROM venues JOIN Performance ON venues.VenueCode = Performance.VenueCode
WHERE venues.VenueCode!="VV" 
AND Performance.startDateTime >= DATE_SUB(NOW(), INTERVAL 1 DAY)
ORDER BY venues.VenueName

 

Be aware that NOW() returns a DateTime, so the result may be different at different times of the day. You might consider using CURRENT_DATE() instead.

Link to comment
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.