从数据库中取出的时间类型的数据怎样只取日期部分而不取时间部分

从数据库中取出的时间类型的数据怎样只取日期部分而不取时间部分,第1张

SQL中只获取日期

datatime型的字段MAKE_DATE,里面的值是'2002-12-02 00:00:00000',

我用什么函数,或者简便的方法,可以取出像这样的数据'2002-12-02'(只取日期,月日要补零)

要得到不同格式的日期和时间,你需要使用函数CONVERT()。例如,当下面的这个语句执行时,显示的时间将包括毫秒:

SELECT CONVERT(VARCHAR(30),GETDATE(),9)

注意例子中数字9的使用。这个数字指明了在显示日期和时间时使用哪种日期和时间格式。当这个语句执行时,将显示如下的日期和时间:

Nov 30 1997 3:29:55:170AM

(1 row(s) affected)

在函数CONVERT()中你可以使用许多种不同风格的日期和时间格式。下表显示了所有的格式。

日期和时间的类型

类型值 标准 输出

0 Default mon dd yyyy hh:miAM

1 USA mm/dd/yy

2 ANSI yymmdd

3 British/French dd/mm/yy

4 German ddmmyy

5 Italian dd-mm-yy

6 - dd mon yy

7 - mon dd,yy

8 - hh:mi:ss

9 Default + milliseconds--mon dd yyyy

hh:mi:ss:mmmAM(or )

10 USA mm-dd-yy

11 JAPAN yy/mm/dd

12 ISO yymmdd

13 Europe Default + milliseconds--dd mon yyyy

hh:mi:ss:mmm(24h)

14 - hh:mi:ss:mmm(24h)

类型0,9,和13总是返回四位的年。对其它类型,要显示世纪,把style值加上100。类型13和14返回24小时时钟的时间。类型0,7,和13返回的月份用三位字符表示(用Nov代表November)

对表中所列的每一种格式,你可以把类型值加上100来显示有世纪的年(例如,00年将显示为2000年)。例如,要按日本标准显示日期,包括世纪,你应使用如下的语句:

SELECT CONVERT(VARCHAR(30),GETDATE(),111)

在这个例子中,函数CONVERT()把日期格式进行转换,显示为1997/11/30

方法:

select convert(varchar(8),getdate(),112)

--------

20021203

select convert(varchar(10),getdate(),120)

----------

2002-12-03

date1="2008-8-8"

date2="2008-5-5"

sql="select from biao where (date=#"date1"# or date>#"date1"#)and (date=#"date1"# or date<#"date1"#)"

在刚接触数据库 *** 作时就发现时间在Java和数据库自己传输时经常出错,后来自己不断的调试得出一种解决方法:

在建立javaBean时将变量如time直接定义为Date类型,而数据库表单里的数据类型定义为datetime。当向数据库增加一条数据时,

stmsetString(4, new Date()toLocaleString());

当然有人会觉得,我定义的是Date类型的,为什么要用setString,因为后面我是使用了当前时间的一个字符串,所以要用String类型,

而且写sql语句时写数据表里数据名就可以,string直接存进去完全没有问题,只是我调出来的比较好玩的发现,前面我用date的几种

属性也不成功,应该是我水平有限,如果大家有好的方法请多多指教。

而读取一条数据时rsgetDate();

第二种方法就比较正经:

在建立javaBean是将变量如time直接定义为 Timestamp 类型,这是sql里的一种类型,同样的数据表里数据类型还是定义为datetime,

当向数据库增加一条数据时,stmsetTimestamp(6,new Timestamp(new Date()getTime()));

很正常的一种写法,而读取数据时rsgetTimestamp()

这是我常用的两种方法。

可以尝试以下代码:

javautilDate dt = new javautilDate();

javatextSimpleDateFormat sdf =

new javatextSimpleDateFormat("yyyy-MM-dd HH:mm:ss");

String currentTime = sdfformat(dt);

然后把currentTime 插入数据库的datetime字段就可以了,取的时候也一样,取出来的

MYSQL可以用DATE函数, SQLSERVER 可以用CAST(XXX AS DATE)

不过比较时间可以直接用DATEDIFF()(MYSQL/SQLSERVER)/TIMESTAMPDIFF(MYSQL)

以上就是关于从数据库中取出的时间类型的数据怎样只取日期部分而不取时间部分全部的内容,包括:从数据库中取出的时间类型的数据怎样只取日期部分而不取时间部分、怎么在数据库里取的两个Date类型之间的数据、java怎么从数据库中取出时间等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/sjk/9823173.html

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

发表评论

登录后才能评论

评论列表(0条)

保存