在论坛上看到,以前很喜欢写SQL,收藏下来重温SQL时看看:
|
declare @x int declare @y int declare @c varchar(6000) set @x = 1 while(@x<=9) begin select @y=1,@c='' while(@y<=@x) begin select @c=@c+cast(@y as varchar)+'x'+cast(@x as varchar)+'=' +(case when len(ltrim(@x*@y))>1 then '' else ' ' end)+ltrim(@x*@y)+' ' select @y=@y+1 end print @c+char(10) select @x=@x+1 end
select max(case when a < 1 then '' else '1*'+cast(a as varchar)+'='+cast(a*1 as varchar) end) as [1], max(case when a < 2 then '' else '2*'+cast(a as varchar)+'='+cast(a*2 as varchar) end) as [2], max(case when a < 3 then '' else '3*'+cast(a as varchar)+'='+cast(a*3 as varchar) end) as [3], max(case when a < 4 then '' else '4*'+cast(a as varchar)+'='+cast(a*4 as varchar) end) as [4], max(case when a < 5 then '' else '5*'+cast(a as varchar)+'='+cast(a*5 as varchar) end) as [5], max(case when a < 6 then '' else '6*'+cast(a as varchar)+'='+cast(a*6 as varchar) end) as [6], max(case when a < 7 then '' else '7*'+cast(a as varchar)+'='+cast(a*7 as varchar) end) as [7], max(case when a < 8 then '' else '8*'+cast(a as varchar)+'='+cast(a*8 as varchar) end) as [8], max(case when a < 9 then '' else '9*'+cast(a as varchar)+'='+cast(a*9 as varchar) end) as [9] from ( select 1 as a union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9 ) as t1 group by a
SQL code
--这样会不会好看一些
select
max(casewhen a>0then'1*'+a+'='+ltrim(a*1)end)[1],
max(casewhen a>1then'2*'+a+'='+ltrim(a*2)end)[2],
max(casewhen a>2then'3*'+a+'='+ltrim(a*3)end)[3],
max(casewhen a>3then'4*'+a+'='+ltrim(a*4)end)[4],
max(casewhen a>4then'5*'+a+'='+ltrim(a*5)end)[5],
max(casewhen a>5then'6*'+a+'='+ltrim(a*6)end)[6],
max(casewhen a>6then'7*'+a+'='+ltrim(a*7)end)[7],
max(casewhen a>7then'8*'+a+'='+ltrim(a*8)end)[8],
max(casewhen a>8then'9*'+a+'='+ltrim(a*9)end)[9]
from (
select ltrim(number) afrom
master..spt_values
where type='p'andnumber
between1and9
) t group
by a
SQL code
select '1*'+a+'='+CAST(1*1*(case when a>=1Then a else NULL end) as varchar) as [1], '2*'+a+'='+CAST(2*1*(case when a>=2Then a else NULL end) as varchar) as [2], '3*'+a+'='+CAST(3*1*(case when a>=3Then a else NULL end) as varchar) as [3], '4*'+a+'='+CAST(4*1*(case when a>=4Then a else NULL end) as varchar) as [4], '5*'+a+'='+CAST(5*1*(case when a>=5Then a else NULL end) as varchar) as [5], '6*'+a+'='+CAST(6*1*(case when a>=6Then a else NULL end) as varchar) as [6], '7*'+a+'='+CAST(7*1*(case when a>=7Then a else NULL end) as varchar) as [7], '8*'+a+'='+CAST(8*1*(case when a>=8Then a else NULL end) as varchar) as [8], '9*'+a+'='+CAST(9*1*(case when a>=9Then a else NULL end) as varchar) as [9] from (select top 9 CAST(Row_Number()over (order by name) as varchar(10) ) as a from master..spt_values )b
SQL code
-
declare @a smallint, @b smallint, @str varchar(1000) set @a=1 while @a<=9 begin set @b=1 set @str='' while @b<=@a begin select @str=@str+convert(varchar(1),@b)+'*'+convert(varchar(1),@a)+'='+convert(varchar(2),@a*@b)+space(2) set @b=@b+1 end print @str set @a=@a+1 end

2574

被折叠的 条评论
为什么被折叠?



