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

后台我是将数据想调入了内存,前台用的<%# DataBinder.Eval(Container.DataItem, "diary_date") %>读出得datetime数据类型得时间,2008-1-1 00:00:00 怎样能让页面只显示08-1-1 ?

SQL中只获取日期值

datatime型的字段MAKE_DATE,里面的值是'2002-12-02 00:00:00.000',
我用什么函数,或者简便的方法,可以取出像这样的数据'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 yy.mm.dd
3 British/French dd/mm/yy
4 German dd.mm.yy
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

参考资料:http://www.cnblogs.com/tonyman/archive/2007/04/18/717783.html

温馨提示:内容为网友见解,仅供参考
第1个回答  2008-10-02
换成
<%# DataBinder.Eval(Container.DataItem, "diary_date","{0:yyyy-MM-dd}") %>
或者
<%# DataBinder.Eval(Container.DataItem, "diary_date","yyyy-MM-dd") %>
试试,应该是第一种,不太记得了本回答被提问者采纳
第2个回答  2008-09-30
换成
<%#
DataBinder.Eval(Container.DataItem,
"diary_date","{0:yyyy-MM-dd}")
%>
或者
<%#
DataBinder.Eval(Container.DataItem,
"diary_date","yyyy-MM-dd")
%>
试试,应该是第一种,不太记得了

从数据库中取出的时间类型的数据怎样只取日期部分而不取时间部分?
datatime型的字段MAKE_DATE,里面的值是'2002-12-02 00:00:00.000',我用什么函数,或者简便的方法,可以取出像这样的数据'2002-12-02'(只取日期,月日要补零)要得到不同格式的日期和时间,你需要使用函数CONVERT()。例如,当下面的这个语句执行时,显示的时间将包括毫秒:SELECT CONVERT(VARCH...

PHP如何将从数据库中取出的时间只保留日期部分
LZ的问题直接用PHP的 $time = date('Y-m-d', $time); 即可解决

数据库中怎样去掉日期类型后面的时间,只保留日期
tmpDate:=DateToStr(Adoquery1.Fieldbyname('日期').AsDatetime);再用tmpDate更新日期字段 逐行执行即可

数据库时间我要怎样只显示日期不显示时间的???
你好,进入表的【设计视图】,这个应当会进入吧(右键表名---设计视图)选择时间的那项,在数据类型中,选【日期-时间】,然后在下面的【格式】里选择【短日期】然后保存就好了满意请设置为满意答案,谢谢

数据库中存放的日期是用now()写的 在ASP中如何只调用日期而不要时间
asp里now()是日期和时间,date()只有当前日期 数据库里取出的时间用convert(varchar(10),时间字段,120)这样读取出来的没有时间

在java中用mysql在数据库中读取一个日期,但是读出来之后有时分秒,我如...
‘日期’ from test 2.java程序 SimpleDateFormat dateFm = new SimpleDateFormat("yyyy-MM-dd");String dateTime = dateFm.format(new java.util.Date());如果你直接就想要这样的格式不需要其他的格式那么就数据库的时候就格式化,如果还需要其他的不同形式的时间格式那么就是用程序中处理的方式 ...

java中从数据库中读出日期类型后怎么提取年月或者日?
Date d1 = new SimpleDateFormat("yyyy年MM月dd日").parse(str0);\/\/定义起始日期 SimpleDateFormat sdf0 = new SimpleDateFormat("yyyy");SimpleDateFormat sdf1 = new SimpleDateFormat("MM");SimpleDateFormat sdf2= new SimpleDateFormat("dd");String str1 = sdf0.format(d1);String ...

数据库中的数据怎样提取时间的年和月,其余的都不显示
DATEXXXX是date类型可以这么转化 SELECT TO_CHAR(DATEXXXX,'YYYY-MM') 这样写就行

java 数据库中的时间数据是日期时间型的,就是带几分几秒的,怎么吧后面...
如果是查询数库的话, 可以直接用 to_char 把时间转成字符串,并指令format 格式

如何让数据库里的时间只显示年月日asp.net
<%# DataBinder.Eval(Container, "DataItem.起始日期","{0:d}") %>

相似回答