📄 431.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数据操作基础(中级) 10</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数据操作基础(中级) 10 [<a href=http://www.jsp001.com/forum/showthread.php?goto=newpost&threadid=431>查看别人的评论</a>]<br>
<hr><p>由 amtd 发布于: 2001-02-14 09:24</p><p><img src="images/icons/icon1.gif" alt="Post" border=0> </p><p>操作日期和时间<br><br>日期和时间函数对建立一个站点是非常有用的。站点的主人往往对一个表中的数据何时被更新感兴趣。通过日期和时间函数,你可<br>以在毫秒级跟踪一个表的改变。<br><br>返回当前日期和时间<br><br>通过函数GETDATE(),你可以获得当前的日期和时间。例如,语句SELECT GETDATE()返回如下的结果:<br><br>……………………………..<br><br>NOV 30 1997 3:29AM<br><br>(1 row(s) affected)<br><br>显然,如果你将来使用这个函数,你得到的日期将比这个时间晚,或者梗早。<br><br>函数GETDATE()可以用来作为DATEDIME()型字段的缺省值。这对插入记录时保存当时的时间是有用的。例如,假设有一个表用<br>来保存你站点上的活动日志。每当有一个访问者访问到你的站点时,就在表中添加一条新记录,记下访问者的名字,活动,和进行<br>访问的时间。要建立一个表,其中的记录包含有当前的日期和时间,可以添加一个DATETIME型字段,指定其缺省值为函数GETDATE<br>()的返回值,就象这样:<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>毫秒级(确切地说,可以精确到3.33毫秒)。<br><br>要得到不同格式的日期和时间,你需要使用函数CONVERT()。例如,当下面的这个语句执行时,显示的时间将包括毫秒:<br><br>SELECT CONVERT(VARCHAR(30),GETDATE(),9)<br><br>注意例子中数字9的使用。这个数字指明了在显示日期和时间时使用哪种日期和时间格式。当这个语句执行时,将显示如下的日期和<br>时间:<br><br>…………………………………..<br><br>Nov 30 1997 3:29:55:170AM<br><br>(1 row(s) affected)<br><br>在函数CONVERT()中你可以使用许多种不同风格的日期和时间格式。表11.1显示了所有的格式。<br><br>表11.1 日期和时间的类型<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>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。类型13和14返回24小时时钟的时间。类型0,<br>7,和13返回的月份用三位字符表示(用Nov代表November).<br><br>对表11.1中所列的每一种格式,你可以把类型值加上100来显示有世纪的年(例如,00年将显示为2000年)。例如,要按日本标准<br>显示日期,包括世纪,你应使用如下的语句:<br><br>SELECT CONVERT(VARCHAR(30),GETDATE(),111)<br><br>在这个例子中,函数CONVERT()把日期格式进行转换,显示为1997/11/30<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>DATEPART()抽取月份,因为mm代表月份。下面是这个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>部分,如表11.2所示。<br><br>表11.2 日期的各部分及其简写<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()返回整数是有用的。但是,上例中的查询结果(2,5)不是十分易读。<br>要以更易读的格式得到部分的日期和时间,你可以使用函数DATENAME(),如下例所示:<br><br>SELECT site_name ‘Site Name’<br><br>DATENAME(mm,site_entrydate) ‘Month Posted’<br><br>FROM site_directory<br><br>函数DATENAME()和函数DATEPART()接收同样的参数。但是,它的返回值是一个字符串,而不是一个整数。下面是上例该用<br>DATENAME()得到的结果:<br><br>Site Name Month Postec<br><br>………………………………………………………………….<br><br>Yahoo February<br><br>Microsoft June<br>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -