T-SQL

以复习为目的吧,整理了自己以前在学习T-SQL时的 常用语句下载

获取当前日期时间

1 select getdate()
2 --结果:2012-07-12 06:20:58.670

获取星期几

----返回table
CREATE FUNCTION [dbo].[WeekDayName]
(    
)
RETURNS @WeekDayName TABLE([Id] INT,[WeekDayName] NVARCHAR(15))
AS
BEGIN    
    INSERT INTO @WeekDayName ([Id],[WeekDayName]) VALUES (0,'Saturday'),(1,'Sunday'),(2,'Monday'),(3,'Tuesday'),(4,'Wednesday'),(5,'Thursday'),(6,'Friday')
    RETURN
END
----返回名称
CREATE FUNCTION [dbo].[WeekDayNameOfDate]
(
  @Date DATETIME
)
RETURNS NVARCHAR(10)
BEGIN
RETURN
    CASE (DATEPART(dw, @Date) + @@DATEFIRST) % 7
    WHEN 0 THEN 'Saturday'
    WHEN 1 THEN 'Sunday'
    WHEN 2 THEN 'Monday'
    WHEN 3 THEN 'Tuesday'
    WHEN 4 THEN 'Wednesday'
    WHEN 5 THEN 'Thursday'
    WHEN 6 THEN 'Friday'    
  END
END

----调用表值函数 select * from dbo.WeekDayName()
----调用标量值函数select dbo.WeekDayNameOfDate('2012-01-03')
select getdate(),datename(weekday,getdate()),datepart(weekday,getdate())
--datename 返回星期名称;
--datepart 返回数值;
--例子:
select   
case   datepart(dw,getdate()) 
when   1   then   '星期天 ' 
when   2   then   '星期一 ' 
when   3   then   '星期二 ' 
when   4   then   '星期三 ' 
when   5   then   '星期四 ' 
when   6   then   '星期五 ' 
when   7   then   '星期六 ' 
end

下面是一些常用的关于时间日期的方法

 

View Code
  1 select getdate()
  2 --结果2011-10-23 11:06:23.390
  3 
  4 select datediff(yyyy,getdate(),'2011-01-01')
  5 select datediff(yyyy,getdate(),'2010-1-1')
  6 select datediff(yyyy,getdate(),'2012-1-1')
  7 
  8 --可用于判断数据库里面的数据是否属于同年
  9 --如果为同一年则返回0
 10 --前年日期返回负数
 11 --明后年日期返回大于零的正整数
 12 ------------------------------------
 13 --一个月第一天的
 14 Select DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)
 15 
 16 --本周的星期一
 17 Select DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)
 18 
 19 --一年的第一天
 20 Select DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)
 21 
 22 --季度的第一天
 23 Select DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)
 24 
 25 --当天的半夜
 26 Select DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)
 27 
 28 --上个月的最后一天
 29 Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))
 30 
 31 --去年的最后一天
 32 Select dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))
 33 
 34 --本月的最后一天
 35 Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))
 36 
 37 --本年的最后一天
 38 Select dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))
 39 
 40 --本月的第一个星期一
 41 select DATEADD(wk, DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0) 
 42 -------------------------------------------
 43 --建立一个表,其中的记录包含有当前的日期和时间,可以添加一个DATETIME型字段,指定其缺省值为函数GETDATE()的返回值,就象这样:
 44 
 45 Create TABLE #site_log (username VARCHAR(40),useractivity VARCHAR(100),entrydate DATETIME DEFAULT GETDATE())
 46 drop table #site_log
 47 
 48 --转换日期和时间
 49 --函数GETDATE()的返回值在显示时只显示到秒。实际上,SQL Sever内部时间可以精确到毫秒级(确切地说,可以精确到3.33毫秒)
 50 Select CONVERT(VARCHAR(30),GETDATE(),9)
 51 在函数CONVERT()中你可以使用许多种不同风格的日期和时间格式
 52 日期和时间的类型:
 53 类型值   标准        输出
 54 0         Default    mon dd yyyy hh:miAM
 55 1         USA        mm/dd/yy
 56 2         ANSI    yy.mm.dd
 57 3         British/French dd/mm/yy
 58 4         German    dd.mm.yy
 59 5         Italian    dd-mm-yy
 60 6         -        dd mon yy
 61 7         -        mon dd,yy
 62 8         -        hh:mi:ss
 63 9         Default    + milliseconds--mon dd yyyy    hh:mi:ss:mmmAM(or )
 64 10        USA        mm-dd-yy
 65 11        JAPAN    yy/mm/dd
 66 12        ISO        yymmdd
 67 13        Europe    Default + milliseconds--dd mon yyyy hh:mi:ss:mmm(24h)
 68 14        -        hh:mi:ss:mmm(24h)
 69 
 70 select convert(varchar(30),getdate(),106)
 71 select convert(varchar(30),getdate(),6)
 72 /**类型0,9,和13总是返回四位的年。
 73     对其它类型,要显示世纪,把style值加上100。
 74     类型13和14返回24小时时钟的时间。
 75     类型0,7,和13返回的月份用三位字符表示(用Nov代表November)
 76     对表中所列的每一种格式,你可以把类型值加上100来显示有世纪的年(例如,00年将显示为2000年)*/
 77 
 78 --抽取日期和时间
 79 --在许多情况下,也许只想得到日期和时间的一部分,而不是完整的日期和时间。为了抽取日期的特定部分,你可以使用函数DATEPARt()
 80 
 81 select datepart(dd,getdate())
 82 select datepart(mm,getdate())
 83 select datepart(yyyy,getdate())
 84 select datepart(yy,getdate())
 85 --函数DATEPART()的参数是两个变量。第一个变量指定要抽取日期的哪一部分;第二个变量是实际的数据。在这个例子中,函数DATEPART()抽取月份,因为mm代表月份。下面是这个Select 语句的输出结果:
 86 --函数DATEPART()的返回值是一个整数
 87 
 88 --日期的各部分及其简写
 89 日期部分    简写    值
 90 year        yy        1753--9999
 91 quarter     qq        1--4
 92 month        mm        1--12
 93 day of year dy        1--366
 94 day            dd        1--31
 95 week        wk        1--53
 96 weekday     dw        1--7(Sunday--Saturday)
 97 hour        hh        0--23
 98 minute        mi        0--59
 99 second        ss        0--59
100 milisecond    ms        0--999
101 
102 --当你需要进行日期和时间的比较时,使用函数DATEPART()返回整数是有用的。要以更易读的格式得到部分的日期和时间,你可以使用函数DATENAME(),如下例所示:
103 
104 Select site_name ‘Site Name’
105 DATENAME(mm,site_entrydate) ‘Month Posted’
106 FROM site_directory
107 
108 select datename(mm,getdate())
109 
110 --函数DATENAME()和函数DATEPART()接收同样的参数
111 --它的返回值是一个字符串,而不是一个整数
112 
113 --可以用函数DATENAME()来抽取一个星期中的某一天。下面的这个例子同时抽取一周中的某一天和日期中的月份:
114 
115 select datename(dw,getdate())+'-'+datename(mm,getdate()) as 'Day and Month Posted'
116 
117 --返回日期和时间范围
118 --当分析表中的数据时,也许希望取出某个特定时间的数据
119 --也许对特定的某一天中,比如说2000年12月25日――访问者在你站点上的活动感兴趣,要取出这种类型的数据,你也许会试图使用这样的Select语句
120 Select * FROM weblog Where entrydate="12/25/20000"
121 --不要这样做。这个Select语句不会返回正确的记录
122 --它将只返回日期和时间是12/25/2000 12:00:00:000AM的记录,换句话说,只有刚好在午夜零点输入的记录才被返回。
123 
124 --问题是SQL Sever将用完整的日期和时间代替部分日期和时间。
125 --例如,当你输入一个日期,但不输入时间时,SQL Sever将加上缺省的时间"00:00:00:000AM"
126 --当你输入一个时间,但不输入日期时,SQL Sever将加上缺省的日期"Jan 1 1900"。
127 --要返回正确的记录,你需要适用日期和时间范围。有不止一种途径可以做到这一点。例如,下面的这个Select 语句将能返回正确的记录:
128 
129 create table #dt(da datetime,id int)--验证sql缺省日期时间
130 insert into #dt values('2011-10-10',1)
131 insert into #dt values('09:10:10',2)
132 select * from #dt
133 drop table #dt
134 
135 Select * FROM weblog 
136 Where entrydate>=12/25/2000AND entrydate<12/26/2000137 --这个语句可以完成任务,因为它选取的是表中的日期和时间大于等于12/25/2000 00:00:00:000AM并小于12/26/2000 00:00:00:000AM的记录。换句话说,它将正确地返回2000年圣诞节这一天输入的每一条记录。
138 --另一种方法是,你可以使用LIKE来返回正确的记录。通过在日期表达式中包含通配符"%",你可以匹配一个特定日期的所有时间。这里有一个例子:
139 
140 Select * FROM weblog Where entrydate LIKEDec 25 2000%141 
142 --这个语句可以匹配正确的记录。因为通配符“%”代表了任何时间。
143 --使用这两种匹配日期和时间范围的函数,你可以选择某个月,某一天,某一年,某个小时,某一分钟,某一秒,甚至某一毫秒内输入的记录。但是,如果你使用 LIKE 来匹配秒或毫秒,你首先需要使用函数CONVERT()把日期和时间转换为更精确的格式
144 
145 --比较日期和时间
146 --最后,还有两个日期和时间函数对根据日期和时间取出记录是有用的。使用函数DATEADD()和DATEDIFF(),你可以比较日期的早晚。例如,下面的Select语句将显示表中的每一条记录已经输入了多少个小时:
147 
148 select datediff(mm,getdate(),'2011-10-10')
149 
150 --函数DADEDIFF()的参数是三个变量。第个变量指定日期的某一部分。在这个例子中,是按小时对日期进行比较,在日期2000年11月1日和2000年11月30日的指定时间之间有689个小时。另外两个参数是要进行比较的时间。为了返回一个正数,较早的时间应该先给。
151 --函数DATEADD()把两个日期相加。当你需要计算截止日期这一类的数据时,这个函数是有用处的
152 
153 
154 select dateadd(mm,-1,getdate());
155 
156 --函数DATEADD()的参数有三个变量。第一个变量代表日期的某一部分,这个例子用到了代表月份的mm。
157 --第二个变量指定了时间的间隔――在本例中是一个月。
158 --最后一个变量是一个日期
159 --注意:
160 --使用函数DATEADD()把一个日期加上一个月,它并不加上30天。这个函数只简单地把月份值加1。
161 
162 
163 ---------------------------------------
164 Select CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AM 
165 Select CONVERT(varchar(100), GETDATE(), 1): 05/16/06 
166 Select CONVERT(varchar(100), GETDATE(), 2): 06.05.16 
167 Select CONVERT(varchar(100), GETDATE(), 3): 16/05/06 
168 Select CONVERT(varchar(100), GETDATE(), 4): 16.05.06 
169 Select CONVERT(varchar(100), GETDATE(), 5): 16-05-06 
170 Select CONVERT(varchar(100), GETDATE(), 6): 16 05 06 
171 Select CONVERT(varchar(100), GETDATE(), 7): 05 16, 06 
172 Select CONVERT(varchar(100), GETDATE(), 8): 10:57:46 
173 Select CONVERT(varchar(100), GETDATE(), 9): 05 16 2006 10:57:46:827AM 
174 Select CONVERT(varchar(100), GETDATE(), 10): 05-16-06 
175 Select CONVERT(varchar(100), GETDATE(), 11): 06/05/16 
176 Select CONVERT(varchar(100), GETDATE(), 12): 060516 
177 Select CONVERT(varchar(100), GETDATE(), 13): 16 05 2006 10:57:46:937 
178 Select CONVERT(varchar(100), GETDATE(), 14): 10:57:46:967 
179 Select CONVERT(varchar(100), GETDATE(), 20): 2006-05-16 10:57:47 
180 Select CONVERT(varchar(100), GETDATE(), 21): 2006-05-16 10:57:47.157 
181 Select CONVERT(varchar(100), GETDATE(), 22): 05/16/06 10:57:47 AM 
182 Select CONVERT(varchar(100), GETDATE(), 23): 2006-05-16 
183 Select CONVERT(varchar(100), GETDATE(), 24): 10:57:47 
184 Select CONVERT(varchar(100), GETDATE(), 25): 2006-05-16 10:57:47.250 
185 Select CONVERT(varchar(100), GETDATE(), 100): 05 16 2006 10:57AM 
186 Select CONVERT(varchar(100), GETDATE(), 101): 05/16/2006 
187 Select CONVERT(varchar(100), GETDATE(), 102): 2006.05.16 
188 Select CONVERT(varchar(100), GETDATE(), 103): 16/05/2006 
189 Select CONVERT(varchar(100), GETDATE(), 104): 16.05.2006 
190 Select CONVERT(varchar(100), GETDATE(), 105): 16-05-2006 
191 Select CONVERT(varchar(100), GETDATE(), 106): 16 05 2006 
192 Select CONVERT(varchar(100), GETDATE(), 107): 05 16, 2006 
193 Select CONVERT(varchar(100), GETDATE(), 108): 10:57:49 
194 Select CONVERT(varchar(100), GETDATE(), 109): 05 16 2006 10:57:49:437AM 
195 Select CONVERT(varchar(100), GETDATE(), 110): 05-16-2006 
196 Select CONVERT(varchar(100), GETDATE(), 111): 2006/05/16 
197 Select CONVERT(varchar(100), GETDATE(), 112): 20060516 
198 Select CONVERT(varchar(100), GETDATE(), 113): 16 05 2006 10:57:49:513 
199 Select CONVERT(varchar(100), GETDATE(), 114): 10:57:49:547 
200 Select CONVERT(varchar(100), GETDATE(), 120): 2006-05-16 10:57:49 
201 Select CONVERT(varchar(100), GETDATE(), 121): 2006-05-16 10:57:49.700 
202 Select CONVERT(varchar(100), GETDATE(), 126): 2006-05-16T10:57:49.827: 
203 Select CONVERT(varchar(100), GETDATE(), 131): 18/04/1427 10:57:49:920AM 

 

各系统表的作用
View Code
 1 MSSQL中各个系统表的作用 
 2 
 3 sysaltfiles    主数据库               保存数据库的文件
 4 syscharsets    主数据库               字符集与排序顺序
 5 sysconfigures  主数据库               配置选项
 6 syscurconfigs  主数据库               当前配置选项
 7 sysdatabases   主数据库               服务器中的数据库
 8 syslanguages   主数据库               语言
 9 syslogins      主数据库               登陆帐号信息
10 sysoledbusers  主数据库               链接服务器登陆信息
11 sysprocesses   主数据库               进程
12 sysremotelogins主数据库               远程登录帐号
13 syscolumns     每个数据库             列
14 sysconstrains  每个数据库             限制
15 sysfilegroups  每个数据库             文件组
16 sysfiles       每个数据库             文件
17 sysforeignkeys 每个数据库             外部关键字
18 sysindexs      每个数据库             索引
19 sysmenbers     每个数据库             角色成员
20 sysobjects     每个数据库             所有数据库对象
21 syspermissions 每个数据库             权限
22 systypes       每个数据库             用户定义数据类型
23 sysusers       每个数据库             用户
24 
25 
26 --用什么方法可以得到一个表中所有的列名。SQl语句。
27 select   列名=name   from   syscolumns   where   id=object_id(N'要查的表名') 
28 
29 use gpStrudy
30 select   name="name"   from   syscolumns   where   id=object_id(N'bookTable')

goto在T-SQL中的用法

View Code
 1 /**
 2 GOTO语句可以实现无条件跳转
 3 语法格式 GOTO  lable 其中lable为要跳转到的语句标号
 4 遇到GOTO语句时直接跳转到lable标签处继续执行,而goto之后的语句不再执行
 5 **/
 6 
 7 declare @result int=0
 8 declare @sn int =0
 9 loop_1:--定义标号
10 set @result=@result+@sn
11 set @sn=@sn+1
12 if(@sn<=100)
13 goto loop_1--如果小于100就跳转到loop_1标号处
14 print @result

 

后续将会继续整理出关于T-SQL的相关资料

 
posted @ 2012-07-12 06:28  xyzla  阅读(2739)  评论(3编辑  收藏  举报