菜单

SQL语句【T-SQL汇总】

2019年1月23日 - MySQL

第一看上边一条相比成功语句,都是比较常见的重大字。

前天和我们齐声来享受一下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    认清语句

判断语句用的依旧相比较多的大家依旧来做个例证说美素佳儿下;

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