SQL语句【T-SQL汇总】

发布时间:2019-01-25  栏目:NoSQL  评论:0 Comments

先是看上边一条相比较到位语句,都是比较广泛的基本点字。

前几日和豪门一块来享受一下SQL语句,T-SQL的用法和语法,以及一些例子,目标是协理大家一道来复习一下T-SQL的主干语句,以便在档次中更迅捷的选用,当然对于新手来说就更应当去学习和总括了。我个人感觉数据库那上边对此程序员来说很重点,无论是对于JAVA程序员如故DOTNET程序员以及其它编程人员来说都是必须领会的。为了协助大家更好的过往顾T-SQL,本人使用空闲的时光整治的一瞬T-SQL的讲话和语法。希望对大家有用!

USE Temp;

SELECT empid, YEAR(orderdate) AS orderyear, COUNT(*) AS numorders
FROM Sales.Orders
WHERE custid = 71
GROUP BY empid, YEAR(orderdate)
HAVING COUNT(*) > 1
ORDER BY empid, orderyear;

好的!大家先来看多少个图像:

我们来详细分析一下sql语句的逻辑处理顺序,纵然select在每条语句的率先位,但实际它是被最终才处理的

棱形图片 1三角形图片 2正方形图片 3圆形图片 4矩形图片 5梯形图片 6

1.from  

上边那个图片都是用T-SQL已毕的,小说的末段我们一块来用T-SQL画出那些图片。

2.where

第一,我们初始回忆一下T-SQL的中央语法:

3.group by

函数

abs(x):求相对值

例:    select abs(-3)     值为:3

sqrt(x)求平方根

例:    select sqrt(4)     值为:2.0

rand([0])返回0~1之间的随机float值

floor(X):重临小于或等于X值的最大整数

例:    select floor(34.5)   值为:34

ceiling(X):重回大于或等于X值的矮小整数;

例:    select ceiling(34.5)  值为:35

round(x,length):四舍五入函数,length为正,则对X小数位数四舍五入,length为负,则对X从小数点左边length位起四舍五入,若length既为负数且其相对值超出X整数部分    
数字个数,则函数值为0;

图片 7)

例:    select ROUND(63.567, 1)      值为:63.600

      select ROUND(63.567, -1)     值为:60.000

      select ROUND(63.567, 0)      值为:64.000

      select ROUND(63.567, -3)       值为:0.000

图片 8)

Sign(X):求符号函数,X>0则sign(x)=1;
X=0
则sign(X)=0;X<0 则sign(X)=-1

例:     select sign(-3)        值为:-1

        select sign(3)        值为:1

        select sign(0)         值为:0

Power(X,y):求X的y次方;

例:    select power(4,2)    值为 :16

 

4.having

字符串函数

ASCII(串):再次来到字符表达式最左端字符的ASCII
码值;

例:    select ASCII('bc')   值为:98

CHAR(ASCII码):用于将ASCII
码转换为字符,倘若没有输入0 ~ 255 之间的ASCII
码值,再次来到值为NULL ;

例:    select char(97)    值为:a

Lower(串):把字符串全体变换为小写;    

例:    select lower('QingPingGuo')     值为: qingpingguo

Upper(串)
:把字符串全体转移为大写;

例:    select upper('QingPingGuo')    值为: QINGPINGGUO

LTrim(串), RTrim(串):去掉左右空格;

 例(去左空格):  select '博客园'+LTrim('   青苹果   ')+'博客园'    值为:博客园青苹果    博客园

space(个数):重回指定个数的空格;

replicate(串,次数):将串重复指定次数;

例:    select replicate('青苹果',2)    值为:青苹果青苹果

Left(串, 个数):再次来到已知串从左侧先河指定个数的字符;

例:    select left('青苹果在博客园', 4)    值为:青苹果在

Right(串, 个数):重回已知串从右边初阶指定个数的字符; 

例:    select right('青苹果在博客园', 4)    值为:在博客园

DataLength(串):再次来到串的字节数长度,总括串尾空格。可以用它检查varchar,text等的动态长度;

例:    select datalength('青苹果在博客园')    值为:14

SubString(串, 开始地方,
长度):重返从字符串左侧’起第二地方’起数据为’长度’的字符串。其中表明式可以是字符串或二进制串或含字段名或字符型变量的表明式。在此间要留心一下SUBSTRING()函数没办法用于TEXT
和IMAGE 数据类型;

例:    select substring('青苹果在博客园',5,2)     值为:博客

Len(串)
:重返表明式的长度。注意它回到的是字符数,而不是字节数。不总计串尾空格;

例:    select   len('青苹果cnblogs    ')      值为:10

Replace(‘串1′,’串2′,’串3’):用串3替换串1中出现的拥有串2字符;

例:    select replace('青苹果在北京','北京','博客园')    值为:青苹果在博客园

Stuff(串1, 初叶地点, 长度, 串2):删除串1点名地点上马指定长度的字符串,并在指定地点插入串2;

例:    select stuff('青苹果是程序猿吗?',5,3,'攻城狮')    值为:青苹果是攻城狮吗?

reverse(串)
:将点名的字符串的字符排列顺序颠倒;

例:    select reverse('12345')    值为:54321

charindex(串1,串2):重返串1在串2的上马地点,可从所付出的‘初步地方’举办搜寻;

例:    select charindex('guo','qingpingguo')    值为:9

 

5.select

转移函数

所谓转换函数就是把某种数据类型转换的表明式展现转换成另一种数据类型的函数。
CAST(表达式 AS 数据类型[(长度)])

例:  select  '今天是:' + Cast(GetDate() as char(10))  值为:今天是:07 23 2012

CONVERT(转换后的目的数据类型[(length)],表达式[style])

例:  select  '今天是:' +convert(char(10),getdate())    值为:今天是:07 23 2012

上边来看一个求差值的函数datediff函数;

DATEDIFF(datepart,date1,date2)

例:  select  datediff(yy,'1988.09.14','2012.12.21')  值为:24
    select  datediff(mm,'1988.09.14','2012.12.21')  值为:291

6.order by

聚合函数

聚合函数也就是计算函数,它根本是对一组值举行计算,它的功能分别是:求和(sum)、求最小(min)、求最大(max)、求总行数(count)、求平均值(avg)

例:   求和:select sum(Name) from TableName
       求最小:select min(Name) from TableName
       求最大:select max(Name) from TableName
      求总数:select count(Name) from TableName
      求平均:select avg(Name) from TableName

7.TOP

T-SQL的局地重大字

Print  向客户端再次回到用户新闻

例:  print '青苹果'         屏幕上就会显示“青苹果三个字“

Go     
用来布告SQL一批语句的完工

Distinct   去掉重复值

Declare    用来声称变量

例:  declare @a int

Set    为变量赋值

例:  set @a='青苹果'

While 
在SQL中用来循环(好像在SQL中用来做巡回的紧要性字不多)

图片 9)

语法:    WHILE <条件表达式>
                 BEGIN
                    <命令行或程序块>
                   [BREAK]
                   [CONTINUE]
                   [命令行或程序块]
                 END

图片 10)

While相比较重大,大家来做个例子加深一下对While循环的明白:

图片 11)

declare @a int
set @a=1
while @a<5
begin 
print '青苹果'
set @a=@a+1
end

输出结果:青苹果
     青苹果
     青苹果
     青苹果

图片 12)

if else    认清语句

判断语句用的照旧比较多的大家如故来做个例子说惠氏(WYETH)(Karicare)下;

求:a、b、c八个数的最大值?

图片 13)

declare  @a int,@b int,@c int,@max  int
set @a=1 set @b=2 set @c=3 
if  @a>@b               
   set  @max=@a
else
   set  @max=@b
if  @max<@c
   set  @max=@c      
print   @max

输出结果:3

图片 14)

begin end 
用来设定一个程序块,将在BEGIN…END内的拥有程序视为一个单元执行。

Exists     认清是不是存在

Case  
也是用来判断的,和IF语句几乎,它的格式为:

 CASE  <运算式>
        WHEN <运算式1> THEN  <结果1>
          … 
           WHEN<运算式n> THEN   <结果n>
          [ELSE  <结果n+1>]
  END

 Return
  用来停止方今程序的执行,再次来到到上一个调用它的顺序或其余程序。在括号内可指定一个重返值。

Goto标示符 
用来改变程序执行的流水线,使程序跳到标有标识符的指定的顺序行再持续往下执行。要注意的是作为跳转目的的标识符可为数字与字符的构成,但不可能不以“:”结尾,如:“1023:”
“qingpingguo:”

图片 15)

例子:
        declare @a int 
       set @a = 1  
     qingpignguo:       
     print @a       
       set @a = @a + 1 
       while @a < 6   
      goto qingpignguo

输出结果:12345

图片 16)

最后一个给大家看个好玩的:

Waitfor   
用来刹车程序执行,直到等待指定时间之后,或所设定的时刻已到才继续往下运行程序。

语法:  waitfor {delay '时间'|time '时间'}

解释:

(1)‘时间’必须为DATETIME类型数据,且无法包含日期,如‘10:12:05’

(2)DELAY:用来设定等待的岁月长短,最多为24小时。(是一个时刻距离)

(3)TIME:用来设定等待停止的时间点(是一个切实的日子)

例子:
    waitfor  delay '00:00:03'
   print '你好,我是青苹果'
   go

如上就是T-SQL的富有情节了,接下去大家来利用最终的流年画多少个图形:

直角三角形:

图片 17)

declare @a int 
set @a=1
while(@a<11)
begin
print replace(space(@a),' ','*')
set @a=@a+1
end

图片 18)

直角三角形 输出结果:图片 19

 

正方形:

图片 20)

declare @a int
declare @b int
declare @c nvarchar(100)
set @a=1
set @b=1
set @c=''
while (@a<9)
begin
   while (@b<15)
   begin 
    set @c=@c+'*'
    set @b=@b+1
   end
    print @c 
set @a=@a+1
end

图片 21)

 

正方形 输出结果:图片 22

 

菱形:

图片 23)

declare @a int,@b int
set @a=1 set @b=15

if(@b%2!=1)
print '数字必须都是奇数'
else
while(@a<=@b)
begin
if(@a%2=1)
print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)
set @a=@a+1
end
set @a=@a-2
while (@a<=@b)
begin
if(@a%2=1)
print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)
set @a=@a-1    
if (@a<0)
break
end

图片 24)

菱形 输出结果:图片 25

 

梯形:

图片 26)

declare @a int,@b int
set @a=7 set @b=21
if(@a%2=1)
while(@a<@b)
begin
print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)
set @a=@a+2
end

图片 27)

梯形 输出结果:图片 28

 

矩形:

图片 29)

declare @a int
declare @b int
declare @c nvarchar(100)
set @a=1
set @b=1
set @c=''
while (@a<9)
begin
   while (@b<23)
   begin 
    set @c=@c+'*'
    set @b=@b+1
   end
    print @c 
set @a=@a+1
end

图片 30)

矩形 输出结果:图片 31

 

圆形:

图片 32)

declare @a int,@b int
set @a=9 set @b=13

while (@a<=@b)
begin
if(@a%2=1)
print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)
set @a=@a+1
end
set @a=@a-1
begin
print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)
end
while (@a<=@b)
begin
if(@a%2=1)
print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)
set @a=@a-1
if(@a<10)
break
end
set @a=@a-2
begin
print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)
end

图片 33)

圆形输出结果:图片 34

The End!
以上就是本文的持有情节,可能写的不够周全,有不足的地点希望大家多多补充,多多发布意见!谢谢!

在仔细分析各样执行顺序代表的情趣 (它的实在顺序)

FROM Sales.Orders
WHERE custid = 71
GROUP BY empid, YEAR(orderdate)
HAVING COUNT(*) > 1
SELECT empid, YEAR(orderdate) AS orderyear, COUNT(*) AS numorders
ORDER BY empid, orderyear;

1.从 Orders 表查询数据

2.基于条件筛选客户ID等于71的

3.对客户id和订单年度 进行分组

  1. 再选出大于一个订单的组

5.再次回到查询出的数据 以及你要显得的字段

6.终极对客户id 和订单 举办排序

7.输出

输入的键入顺序和处理顺序不雷同是有缘由的,SQL设计师是为着让用户根据英文的格局提供温馨的呼吁

建议、坑

  1. from 表时  最好给定 库名和表名  Sales.Orders 
    让表突显表示 不用程序检索。
  1. where 子句格外重大  SQL Server 会对where 条件
    举行评估访问请求数据要采纳的目录,通过索引可以大大收缩表扫描时间

再者 where 子句检索 落成后 
它回到的是寻觅结果为True的行  ,但始终铭刻, SQL
数据库使用三值谓词逻辑,也就是说有多少个结实。

True,False 或 UNKNOWN ,  再次回到true 行 并分化等
不回来False  实际上是不回来 False 行 和 UNKNOWN 行
未来会再博客中专门讲NULL。

3.记住除count(*)之外, 
聚合函数都是忽视NULL标记  假诺有一组数据“1,1,3,4,5,null”列名为qty  
表达式Count(*) 重临的是6 但是Count(qty)

是5  count中加以突显值 就会默许寻找已知值 
也足以  count(distinct qty ) 重临的是4 去重新  那几个 可以用来 处理 
重临每个不另行计算问题很方便 它和 select
distinct
有很大性能不一致 未来会细讲 也足以
sum(distinct qty
) 是13
也是用作统计不重复数据。

4.因为 group by
属于行处理 在having 先总括所以having 中可以出现  聚合函数 。

5.像下面的 “YEAR(orderdate)” SQL Server 只对它运行两次 
能辨别查询中重复使用的同等表达式

6.最好别使用 select * 尽管你要查询 所有字段。

7.接纳 order by 对有恢宏双重的字段进行排序是船到江心补漏迟的  例如对日期举办排序
那样一个排序选10条 会有几个被认为是对的结果
所以大家要确保排序字段的数量唯一性, 以及在 select distinct  时 排序
会导致 单个结实对应多个源数据行。

 

留下评论

网站地图xml地图