如何利用MySQL函数查询特定的日期时间

如何利用MySQL函数查询特定的日期时间,第1张

MySQL数据库中year()函数是求某个特定日期中的年份,代码如下:

select '2015-08-11' as date,year('2015-08-11') as year

确定一个日期是一年中的第几个季度,可以用QUARTER()函数实现,代码如下:

SELECT '2015-08-11' AS DATE,QUARTER('2015-08-11') AS QUARTER

返回一个日期是一年中的月份,利用month()函数实现,代码如下:

SELECT '2015-08-11' AS DATE,MONTH('2015-08-11') AS MONTH

获取一个确定日期是一个月份中的多少号,可以用day()函数求得,具体实现代码如下:

SELECT '2015-08-11' AS DATE,DAY('2015-08-11') AS DAY

有时日期中带有时间,而如何获取小时数,这可以利用自带的函数hour()实现,代码如下:

SELECT '2015-08-11 12:20:45' AS DATE,HOUR('2015-08-11 12:20:45') AS HOUR

求取日期时间中的分钟数,可以利用MINUTE()函数实现,代码如下:

SELECT '2015-08-11 12:20:45' AS DATE,MINUTE('2015-08-11 12:20:45') AS MINUTE

最后,获取时间中的秒数,利用SECOND()函数实现,代码如下:

SELECT '2015-08-11 12:20:45' AS DATE,SECOND('2015-08-11 12:20:45') AS SECOND

year(), month(), concat() 是 mysql 特有的函数,其他数据库也有对应的函数,而 hibernate 存在的意义就是屏蔽这些数据库特有的东西,这样的话:

如果数据库的 datetime/date 之类的字段并没有和 Java 的 Date 或 Calender 属性进行映射的话,无论你使用 HQL 还是Criteria 都无法实现对日期的 *** 作,因为 HQL 和 Criteria 都是基于对象的查询方式。

基于对象的查询,如下,先做映射

@Entity

@Table(name="PREFERRED_CUSTOMER")

public PCustomer {

@Column(name = "EXPIRATION_DATE")

@Temporal(TemporalType.DATE)

protected java.util.Date expirationDate// only day, month, year

}

可以使用 HQL 这么查询:

List<PCustomer>list = session

.createQuery("from PCustomer pc where pc.expirationDate = :edate")

.setParameter("edate", new java.util.Date(), TemporalType.DATE)

.list()

hibernate 屏蔽了数据库特有的东西,是为了方便移植,但有的老项目较多地使用了数据库特有的东西,如MSSQL 的 T-SQL,这时,就需要使用 hibernate 对 SQL 的原生支持,Session 提供了 createSQLQuery() 这样的方法,此时的 hibernate 就相当于一个简单的 mapper,只提供对象关系映射,当然,一旦你在代码中使用了对 SQL 的原生支持,移植性就不好了。

此种方式可以使用你所说的 MySQL 函数


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/8658292.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-19
下一篇 2023-04-19

发表评论

登录后才能评论

评论列表(0条)

保存