求一条SQL语句 ( 积分: 0 )

  • 主题发起人 主题发起人 smilyvm
  • 开始时间 开始时间
S

smilyvm

Unregistered / Unconfirmed
GUEST, unregistred user!
有个表tblA
BH SL DW
001 20 件
001 10 支
002 30 件
002 13 根
003 12 件
003 5 张
怎么查询得到;
BH SL
001 20件10支
002 30件13根
003 12件5张
 
用SQL我不知道用存储过程就很简单了噢
 
楼主所提出的是要一条sql语句的话,这是不可能的。因为SQL语言的查询功能是查询数据库中符合查询条件的数据。换言之,就是得到的结果肯定和原数据库中的数值是一致的。而楼主想要的结果中 SL 的值 “20件10支”明显和原数据库中的 SL 的值“20”不同,并且它们的数据类型也不同,这是数据库应用中的大忌。
 
select bh,sl=convert(varchar(11),sum(case dw when '件' then sl else 0 end))+'件'+convert(varchar(11),sum(case dw when '件' then 0 else sl end))+max(case dw when '件' then '' else dw end) from tblA group by bh
 
我想问下如果是
BH SL DW
001 20 件
001 10 支
001 15 支
001 20 根
需要什么结果?
 
select bh,cast(sum(sl) as varchar(10))+dw from a group by bh,dw order by bh
 
也不给我点分分~
 
后面的自己写个变量保存来取过利用游标~
 
http://www.delphibbs.com/delphibbs/dispq.asp?lid=3686192
 
最近没上大富翁,谢谢各位大哥的帮忙.问题已经解决..
再次谢过.
 

Similar threads

S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
D
回复
0
查看
2K
DelphiTeacher的专栏
D
D
回复
0
查看
2K
DelphiTeacher的专栏
D
D
回复
0
查看
1K
DelphiTeacher的专栏
D
后退
顶部