
从数据库中取出的时间类型的数据怎样只取日期部分而不取时间部分?
后台我是将数据想调入了内存,前台用的<%#DataBinder.Eval(Container.DataItem,"diary_date")%>读出得datetime数据类...
后台我是将数据想调入了内存,前台用的<%# DataBinder.Eval(Container.DataItem, "diary_date") %>读出得datetime数据类型得时间,2008-1-1 00:00:00 怎样能让页面只显示08-1-1 ?
展开
3个回答
展开全部
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
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
展开全部
换成
<%# DataBinder.Eval(Container.DataItem, "diary_date","{0:yyyy-MM-dd}") %>
或者
<%# DataBinder.Eval(Container.DataItem, "diary_date","yyyy-MM-dd") %>
试试,应该是第一种,不太记得了
<%# DataBinder.Eval(Container.DataItem, "diary_date","{0:yyyy-MM-dd}") %>
或者
<%# DataBinder.Eval(Container.DataItem, "diary_date","yyyy-MM-dd") %>
试试,应该是第一种,不太记得了
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
换成
<%#
DataBinder.Eval(Container.DataItem,
"diary_date","{0:yyyy-MM-dd}")
%>
或者
<%#
DataBinder.Eval(Container.DataItem,
"diary_date","yyyy-MM-dd")
%>
试试,应该是第一种,不太记得了
<%#
DataBinder.Eval(Container.DataItem,
"diary_date","{0:yyyy-MM-dd}")
%>
或者
<%#
DataBinder.Eval(Container.DataItem,
"diary_date","yyyy-MM-dd")
%>
试试,应该是第一种,不太记得了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询