📄 412.html
字号:
<STYLE type=text/css>
<!--
body,td { font-size:9pt;}
hr { color: #000000; height: 1px}
-->
</STYLE>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd">
<HTML>
<HEAD><TITLE>精选文章 >> SQL之家 >> SQL数据的基本操作(时间和日期)</title>
</head>
<body >
<p><IMG SRC="../image/jsp001_middle_logo.gif" WIDTH="180" HEIGHT="60" BORDER=0 ALT=""></p>
<table width=100% bgcolor="#cccccc" align=center cellpadding="2" cellspacing="0" border=1 bordercolorlight="#000000" bordercolordark="#FFFFFF">
<tr bgcolor="#EFF8FF"><td>
<a href=http://www.jsp001.com/list_thread.php?int_attribute=2>精选文章</a>
>> <a href=http://www.jsp001.com/list_thread.php?forumid=45&int_attribute=2>SQL之家</a>
>> SQL数据的基本操作(时间和日期) [<a href=http://www.jsp001.com/forum/showthread.php?goto=newpost&threadid=412>查看别人的评论</a>]<br>
<hr><p>由 amtd 发布于: 2001-02-13 18:35</p><p><img src="images/icons/icon1.gif" alt="Post" border=0> </p><p> 日期和时间函数对建立一个站点是非常有用的。站点的主人往往对一个表中的数据何时被 <br><br>更新感兴趣。通过日期和时间函数,你可以在毫秒级跟踪一个表的改变。 <br><br>返回当前日期和时间 <br><br>通过函数GETDATE(),你可以获得当前的日期和时间。例如,语句SELECT GETDATE() <br><br>返回如下的结果: <br><br>…………………………… <br><br>NOV 30 1997 3:29AM <br><br>(1 row(s) affected) <br><br>显然,如果你将来使用这个函数,你得到的日期将比这个时间晚,或者更早。 <br><br>函数GETDATE()可以用来作为DATEDIME()型字段的缺省值。这对插入记录时保存 <br><br>当时的时间是有用的。例如,假设有一个表用来保存你站点上的活动日志。每当有一个访 <br><br>问者访问到你的站点时,就在表中添加一条新记录,记下访问者的名字,活动,和进行访 <br><br>问的时间。要建立一个表,其中的记录包含有当前的日期和时间,可以添加一个DATETIME <br><br>型字段,指定其缺省值为函数GETDATE()的返回值,就象这样: <br><br>CREATE TABLE site_log ( <br><br>username VARCHAR(40), <br><br>useractivity VARCHAR(100), <br><br>entrydate DATETIME DEFAULT GETDATE()) <br><br>转换日期和时间 <br><br>你也许已经注意到,函数GETDATE()的返回值在显示时只显示到秒。实际上,SQL Sever <br><br>内部时间可以精确到毫秒级(确切地说,可以精确到3.33毫秒)。 <br><br>要得到不同格式的日期和时间,你需要使用函数CONVERT()。例如,当下面的这个语句 <br><br>执行时,显示的时间将包括毫秒: <br><br>SELECT CONVERT(VARCHAR(30),GETDATE(),9) <br><br>注意例子中数字9的使用。这个数字指明了在显示日期和时间时使用哪种日期和时间格式。 <br><br>当这个语句执行时,将显示如下的日期和时间: <br><br>………………………………….. <br><br>Nov 30 1997 3:29:55:170AM <br><br>(1 row(s) affected) <br><br>在函数CONVERT()中你可以使用许多种不同风格的日期和时间格式。下表显示了所 <br><br>有的格式。 <br><br>表的日期和时间类型 <br><br>类型值 标准输出 <br><br>0 Default mon dd yyyy hh:miAM <br><br>1 USA mm/dd/yy <br><br>2 ANSI yy.mm.dd <br><br>3 British/French dd/mm/yy <br><br>4 German dd.mm.yy <br><br>5 Italian dd-mm-yy <br><br>6 - dd mon yy <br><br>7 - mon dd,yy <br><br>8 - hh:mi:ss <br><br>Default + milliseconds--mon dd yyyy <br><br>hh:mi:ss:mmmAM(or ) <br><br>10 USA mm-dd-yy <br><br>11 JAPAN yy/mm/dd <br><br>12 ISO yymmdd <br><br>13 Europe Default + milliseconds--dd mon yyyy <br><br>hh:mi:ss:mmm(24h) <br><br>14 - hh:mi:ss:mmm(24h) <br><br>类型0,9,和13总是返回四位的年。对其它类型,要显示世纪,把style值加上100。类 <br><br>型13和14返回24小时时钟的时间。类型0,7,和13返回的月份用三位字符表示(用Nov <br><br>代表November). <br><br>对上表中所列的每一种格式,你可以把类型值加上100来显示有世纪的年(例如,00年 <br><br>将显示为2000年)。例如,要按日本标准显示日期,包括世纪,你应使用如下的语句: <br><br>SELECT CONVERT(VARCHAR(30),GETDATE(),111) <br><br>在这个例子中,函数CONVERT()把日期格式进行转换,显示为1997/11/30 <br><br>抽取日期和时间 <br><br>在许多情况下,你也许只想得到日期和时间的一部分,而不是完整的日期和时间。例如, <br><br>假设你想列出你的站点目录中每个站点被查询的月份。这时你不希望完整的日期和时间把 <br><br>网页弄乱。为了抽取日期的特定部分,你可以使用函数DATEPART(),象这样: <br><br>SELECT site_name ‘Site Name’, <br><br>DATEPART(mm,site_entrydate) ‘Month Posted’ FROM site_directory <br><br>函数DATEPART()的参数是两个变量。第一个变量指定要抽取日期的哪一部分;第二个 <br><br>变量是实际的数据。在这个例子中,函数DATEPART()抽取月份,因为mm代表月份。 <br><br>下面是这个SELECT 语句的输出结果: <br><br>Site Name Month Posted <br><br>……………………………………………………………… <br><br>Yahoo 2 <br><br>Microsoft 5 <br><br>Magicw3 5 <br><br>(3 row(s) affected) <br><br>Month Posted列显示了每个站点被查询的月份。函数DATEPART()的返回值是一个整数。 <br><br>你可以用这个函数抽取日期的各个不同部分,如下表所示。 <br><br>表的日期的各部分及其简写 <br><br>日期部分 简写值 <br><br>year yy 1753--9999 <br><br>quarter qq 1--4 <br><br>month mm 1--12 <br><br>day of year dy 1--366 <br><br>day dd 1--31 <br><br>week wk 1--53 <br><br>weekday dw 1--7(Sunday--Saturday) <br><br>hour hh 0--23 <br><br>minute mi 0--59 <br><br>second ss 0--59 <br><br>milisecond ms 0--999 <br><br>当你需要进行日期和时间的比较时,使用函数DATEPART()返回整数是有用的。但是, <br><br>上例中的查询结果(2,5)不是十分易读。要以更易读的格式得到部分的日期和时间你可 <br><br>以使用函数DATENAME(),如下例所示: <br><br>SELECT site_name ‘Site Name’ <br><br>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -