SQL语句(T-SQL汇总) 用T-SQL画出这些图形[MSSQL防范]
本文“SQL语句(T-SQL汇总) 用T-SQL画出这些图形[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
我个人感受数据库这方面关于程序员来说很重要,无论是关于JAVA程序员还是DOTNET程序员以及其他编程人员来说都是必须掌握的.为了帮忙大家更好的往复想T-SQL,本人操纵闲暇的时间整理的一下T-SQL的语句和语法.但愿对大家有效!
好的!我们先来看几个图象:
棱形三角形正方形圆形矩形梯形
上面这些图形都是用T-SQL实现的,文章的最后我们一同来用T-SQL画出这些图形.
首先,我们开始回想一下T-SQL的基本语法:
函数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;
例: 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
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
字符串函数
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
转换函数
所谓转换函数就是把某种数据范例转换的表达式显示转换成另一种数据范例的函数.
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聚合函数
聚合函数也就是统计函数,它主如果对一组值举行计算,它的功效辨别是:求和(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 TableNameT-SQL的一些关键字
Print 向客户端返回用户信息
例: print '青苹果' 屏幕上就会显示"青苹果三个字"
Go 用来告诉SQL一批语句的完毕
Distinct 去掉反复值
Declare 用来声明变量
例: declare @a int
Set 为变量赋值
例: set @a='青苹果'
While 在SQL顶用来循环(仿佛在SQL顶用来做循环的关键字不多)
语法: WHILE <条件表达式> BEGIN <号令行或程序块> [BREAK] [CONTINUE] [号令行或程序块] END
While对比重要,我们来做个例子加深一下对While循环的理解:
declare @a intset @a=1while @a<5begin print '青苹果'set @a=@a+1end
输出后果:青苹果
青苹果
青苹果
青苹果
if else 判断语句
判断语句用的还是对比多的我们还是来做个例子阐明一下;
求:a、b、c三个数的最大值?
declare @a int,@b int,@c int,@max intset @a=1 set @b=2 set @c=3 if @a>@b set @max=@aelse set @max=@bif @max<@c set @max=@c print @max
输出后果:3
begin end 用来设定一个程序块,将在BEGIN…END内的全部程序视为一个单元履行.
Exists 判断能否存在
Case 也是用来判断的,和IF语句差不多,它的格局为:
CASE <运算式> WHEN <运算式1> THEN <后果1> … WHEN<运算式n> THEN <后果n> [ELSE <后果n+1>] END
Return 用于完毕当前途序的履行,返回到上一个调用它的程序或别的程序.在括号内可指定一个返回值.
Goto标示符 用来改变程序履行的流程,使程序跳到标有标识符的指定的程序行再持续往下履行.要注意的是作为跳转目标的标识符可为数字与字符的组合,但必须以":"末尾,如:"1023:" "qingpingguo:"
例子: declare @a int set @a = 1 qingpignguo: print @a set @a = @a + 1 while @a < 6 goto qingpignguo
输出后果:12345
最后一个给大家看个好玩的:
Waitfor 用来暂停程序履行,直到等候指按时间之后,或所设定的时间已到才持续往下运路程序.
语法: waitfor {delay '时间'|time '时间'}
注释:
(1)‘时间'必须为DATETIME范例数据,且不能包含日期,如‘10:12:05'
(2)DELAY:用来设定等候的时间长短,最多为24小时.(是一个时间隔断)
(3)TIME:用来设定等候完毕的时间点(是一个具体的时间)
例子: waitfor delay '00:00:03' print '你好,我是青苹果' go
以上就是T-SQL的全部内容了,接下来我们来操纵最后的时间画几个图形:
直角三角形:
declare @a int set @a=1while(@a<11)beginprint replace(space(@a),' ','*')set @a=@a+1end
直角三角形 输出后果:
正方形:
declare @a intdeclare @b intdeclare @c nvarchar(100)set @a=1set @b=1set @c=''while (@a<9)begin while (@b<15) begin set @c=@c+'*' set @b=@b+1 end print @c set @a=@a+1end
正方形 输出后果:
菱形:
declare @a int,@b intset @a=1 set @b=15if(@b%2!=1)print '数字必须都是奇数'elsewhile(@a<=@b)beginif(@a%2=1)print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)set @a=@a+1endset @a=@a-2while (@a<=@b)beginif(@a%2=1)print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)set @a=@a-1 if (@a<0)breakend
菱形 输出后果:
梯形:
declare @a int,@b intset @a=7 set @b=21if(@a%2=1)while(@a<@b)beginprint space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)set @a=@a+2end
梯形 输出后果:
矩形:
declare @a intdeclare @b intdeclare @c nvarchar(100)set @a=1set @b=1set @c=''while (@a<9)begin while (@b<23) begin set @c=@c+'*' set @b=@b+1 end print @c set @a=@a+1end
矩形 输出后果:
圆形:
declare @a int,@b intset @a=9 set @b=13while (@a<=@b)beginif(@a%2=1)print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)set @a=@a+1endset @a=@a-1beginprint space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)endwhile (@a<=@b)beginif(@a%2=1)print space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)set @a=@a-1if(@a<10)breakendset @a=@a-2beginprint space((@b-@a)/2)+replace(space(@a),' ','*')+space((@b-@a)/2)end
圆形输出后果:
The End! 以上就是本文的全部内容,大概写的不够全面,有不足的地方但愿大家多多增补,多多发表看法!谢谢!
作者:青苹果
以上是“SQL语句(T-SQL汇总) 用T-SQL画出这些图形[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |