从sqlserver数据库中提取日期,并把年月日分别截取出来

从sqlserver数据库中提取日期,并把年月日分别截取出来,第1张

工具/材料:Management Studio。

1、首先在桌面上,点击“Management Studio”图标。

2、然后在该界面中,点击左上角工具栏里“新建查询”按钮。

4、之后在该界面中,输入提取日期,并把年月日分别截取出来的SQL语句“select year(getdate()),month(getdate()),day(getdate())

”。

5、然后在该界面中,点击上方左侧的“执行”按钮。

6、最后在该界面中,显示分别截取出来的年月日。

 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(TemporalTypeDATE)

protected javautilDate expirationDate; // only day, month, year

}

可以使用 HQL 这么查询:

List<PCustomer> list = session

createQuery("from PCustomer pc where pcexpirationDate = :edate")

setParameter("edate", new javautilDate(), TemporalTypeDATE)

list();

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

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

以上就是关于从sqlserver数据库中提取日期,并把年月日分别截取出来全部的内容,包括:从sqlserver数据库中提取日期,并把年月日分别截取出来、hibernate怎么调用mysql中的year,month,concat等函数、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: https://outofmemory.cn/sjk/10186623.html

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

发表评论

登录后才能评论

评论列表(0条)

保存