T-SQL:SQL语句处理顺序的坑(四)

发布时间:2019-01-30  栏目:sqlite  评论: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    看清语句

判定语句用的如故相比多的我们如故来做个例子说美素佳儿(Friso)(Nutrilon)下;

求: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地图