I need to write the common queries for MySQL and Oracle databases. Problem occurs when I have to put date conditions.
For example: there is one field Txn_date
which is in format of '20150116'
in MySQL and '16-JAN-2015'
in Oracle.
I use date_format(now(),'%Y%m%d')
for MySQL and to_char(sysdate,'dd-MON-YYYY')
for Oracle.
Is there any common function of way by which I can use the same function in both Oracle and MySQL?
I tried Txn_date in ( date_format(now(),'%Y%m%d') OR to_char(sysdate,'dd-MON-YYYY') )
but did not work because to_char()
not recognized in MySQL.
First, in MySQL dates usually have the following format when converted implicitly -
2015-01-16
- rather than20150116
. I think you can do the following in both MySQL and Oracle (it is standard SQL) - I've checked it in Oracle (10g) and it works, and it seems to work in my fiddling with MySQL:The string literal to be converted to DATE has to be of the form
yyyy-mm-dd
. Now this will work if your dates are dates and don't have a time portion. Now if your dates do have a time portion, then things become more difficult since MySQL uses theDATE()
function to get the date portion, while Oracle would useTRUNC()
. But you can get around that with judicious use of>=
and<
, e.g.:Now if you want to use
SYSDATE
, the best thing to do would be to use the ANSI standardCURRENT_DATE
orCURRENT_TIMESTAMP
. These can be compared directly with no need for formatting and should work in both MySQL and Oracle. You can also do date arithmetic usingINTERVAL
, in which case you could try the following:UPDATE I've been doing some thinking about this. The query immediately above doesn't really work if you want to get all the rows that have been entered today. The difficulty is that Oracle recognizes ANSI date literals as dates (that is, with no time portion), but there isn't, as far as I know, an ANSI-standard way of converting a date/time value (which an Oracle
DATE
is) to a date. That said, both Oracle and MySQL support the EXTRACT() function, so you should be able to do the following to get today's records:Definitely unwieldy, especially if one has more than one date to consider (which I assume you do since you're using the
IN
operator), but should work on both platforms. See SQL Fiddle Demo here (MySQL) and here (Oracle).MySQL and Oracle use different syntax for converting dates to strings - you'll have to use different queries.