[hibernate-issues] [Hibernate-JIRA] Commented: (HHH-2434) No standard way to calculate date intervals in HQL

Steve Ebersole (JIRA) noreply at atlassian.com
Wed Feb 21 09:37:34 EST 2007


    [ http://opensource.atlassian.com/projects/hibernate/browse/HHH-2434?page=comments#action_26200 ] 

Steve Ebersole commented on HHH-2434:
-------------------------------------

Why not create custom dialects?  At the very least, we need to know exactly for which operations you are requesting support.

DATETIME (the spec term for DATE, TIME, OR TIMESTAMP types) arithmetic is in fact defined by the ANSI SQL spec.  Section 4.5.3 from the '92 spec defines this behavior.  Basically:
DATETIME - DATETIME = INTERVAL
DATETIME +|- INTERVAL = DATETIME
INTERVAL + DATETIME = DATETIME
INTERVAL +|- INTERVAL = INTERVAL
INTERVAL *|/ NUMERIC = INTERVAL
NUMERIC * INTERVAL = INTERVAL

are all defined behaviors.  I cannot say if all databases implement this all correctly however.  And I am pretty sure some treat it differently in terms of what is actually calculated and returned in terms of the INTERVAL returns.

> No standard way to calculate date intervals in HQL
> --------------------------------------------------
>
>          Key: HHH-2434
>          URL: http://opensource.atlassian.com/projects/hibernate/browse/HHH-2434
>      Project: Hibernate3
>         Type: Improvement

>   Components: core
>     Versions: 3.2.0.ga
>  Environment: All
>     Reporter: Don Smith
>     Priority: Minor

>
>
> Date interval calculation is supported differently on different database platforms. Some allow direct arithmetic on columns, i.e. enddate - startdate. Some require functions, datediff(), timestampdiff(), etc. This causes cross-platform issues. For instance, an application I work on has to figure out the dialect that's in use (out of the four we currently support) and create the HQL string differently for each platform. This is undesirable, since we use Hibernate to enable platform neutrality; our installer asks which database the customer wants to deploy to, and sets the dialect. We'd like our codebase to be free of dialect-specific code.
> I propose a standard solution for this, either direct date arithmetic, or a function defintion that is ported across dialects. Timestampdiff seems to be a fairly standard function, although DB2 has different syntax than MySQL and Derby. I've seen hints that timestampdiff is part of the ANSI SQL standard, but do not have access to the documents to determine if that is the case.

-- 
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
   http://opensource.atlassian.com/projects/hibernate/secure/Administrators.jspa
-
For more information on JIRA, see:
   http://www.atlassian.com/software/jira




More information about the hibernate-issues mailing list