读书人

不知这个够不够经典,该怎么解决

发布时间: 2013-01-04 10:04:14 作者: rapoo

不知这个够不够经典


[解决办法]

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



---------------------------
1*1=1
1*2=2 2*2=4
1*3=3 2*3=6 3*3=9
1*4=4 2*4=8 3*4=12 4*4=16
1*5=5 2*5=10 3*5=15 4*5=20 5*5=25
1*6=6 2*6=12 3*6=18 4*6=24 5*6=30 6*6=36
1*7=7 2*7=14 3*7=21 4*7=28 5*7=35 6*7=42 7*7=49
1*8=8 2*8=16 3*8=24 4*8=32 5*8=40 6*8=48 7*8=56 8*8=64
1*9=9 2*9=18 3*9=27 4*9=36 5*9=45 6*9=54 7*9=63 8*9=72 9*9=81
[解决办法]

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

/*******************************

1x1= 1

1x2= 2 2x2= 4

1x3= 3 2x3= 6 3x3= 9

1x4= 4 2x4= 8 3x4=12 4x4=16

1x5= 5 2x5=10 3x5=15 4x5=20 5x5=25

1x6= 6 2x6=12 3x6=18 4x6=24 5x6=30 6x6=36

1x7= 7 2x7=14 3x7=21 4x7=28 5x7=35 6x7=42 7x7=49



1x8= 8 2x8=16 3x8=24 4x8=32 5x8=40 6x8=48 7x8=56 8x8=64

1x9= 9 2x9=18 3x9=27 4x9=36 5x9=45 6x9=54 7x9=63 8x9=72 9x9=81



表示左右对齐了下。
[解决办法]
9*9乘法表?
[解决办法]

[解决办法]
确实不经典,骗水
[解决办法]
感觉少点什么....
[解决办法]
 


--这样会不会好看一些
select
max(case when a>0 then '1*'+a+'='+ltrim(a*1) end) [1],
max(case when a>1 then '2*'+a+'='+ltrim(a*2) end) [2],
max(case when a>2 then '3*'+a+'='+ltrim(a*3) end) [3],
max(case when a>3 then '4*'+a+'='+ltrim(a*4) end) [4],
max(case when a>4 then '5*'+a+'='+ltrim(a*5) end) [5],
max(case when a>5 then '6*'+a+'='+ltrim(a*6) end) [6],
max(case when a>6 then '7*'+a+'='+ltrim(a*7) end) [7],
max(case when a>7 then '8*'+a+'='+ltrim(a*8) end) [8],
max(case when a>8 then '9*'+a+'='+ltrim(a*9) end) [9]
from
(
select ltrim(number) a from master..spt_values
where type='p' and number between 1 and 9
) t group by a


[解决办法]

羡慕大牛们的SQL不知这个够不够经典,该怎么解决
[解决办法]
什么情况?
[解决办法]
牛人!!!学习了!!!
[解决办法]
这个。。。。。。。菜鸟没看懂是什么语言写的。。。。
[解决办法]
楼上的,这个是SQL写的
[解决办法]
经典啊。话说真的么?

[解决办法]
很厉害啊。学习了!!!
[解决办法]


有何经典之处?
[解决办法]
先学习一下,谢谢
[解决办法]
好吧 膜拜了
[解决办法]
还不错,新手可以学学
[解决办法]
强悍a 顶一个
[解决办法]
jingdian!!!
[解决办法]
不知道有没有大神能够讲解的
[解决办法]
没看懂。。。
[解决办法]
不错!!
为什么我都没积分啊!!
[解决办法]

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

这个很直观啊,执行结果也没问题
[解决办法]
哝啥意思
[解决办法]
恩,不错,收藏
[解决办法]
经典!
[解决办法]
呵呵 太经典了
[解决办法]
激动呀,SQL
[解决办法]
引用:
SQL code
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……

艺术品
[解决办法]
9*9乘法表。呵呵。
[解决办法]
恩,不错,收藏
[解决办法]

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

/*
123456789
1*1=1NULLNULLNULLNULLNULLNULLNULLNULL
1*2=22*2=4NULLNULLNULLNULLNULLNULLNULL
1*3=32*3=63*3=9NULLNULLNULLNULLNULLNULL
1*4=42*4=83*4=124*4=16NULLNULLNULLNULLNULL
1*5=52*5=103*5=154*5=205*5=25NULLNULLNULLNULL
1*6=62*6=123*6=184*6=245*6=306*6=36NULLNULLNULL
1*7=72*7=143*7=214*7=285*7=356*7=427*7=49NULLNULL
1*8=82*8=163*8=244*8=325*8=406*8=487*8=568*8=64NULL
1*9=92*9=183*9=274*9=365*9=456*9=547*9=638*9=729*9=81
*/

读书人网 >SQL Server

热点推荐