【发布时间】:2015-08-29 05:06:24
【问题描述】:
我有这个代码:
declare @results varchar(500)
select
@results = coalesce(@results+', ', '') + convert(varchar(12),k.t1)
from
(
select
'('+cast(count(distinct(g.RoomID)) as varchar) + ') '+ rt.ClassName as t1
from
db_pms.Guests g
left join db_pms.RoomTypes rt
on rt.RoomTypeID=g.RoomTypeID
where
g.GroupID = 47 and
g.Status >= 0
group by
g.RoomTypeID,
rt.ClassName
) k
select @results as results
部分
select
'('+ cast(count(distinct(g.RoomID))as varchar) + ') '+ rt.ClassName as t1
from
db_pms.Guests g
left join db_pms.RoomTypes rt
on rt.RoomTypeID=g.RoomTypeID
where
g.GroupID = 47 and
g.Status >= 0
group by
g.RoomTypeID,
rt.ClassName
返回
(1) Люкс
(4) Полулюкс
(2) Стандарт DBL
(6) Стандарт TWN
(1) Стандарт+ TWN
使用后
select @results = coalesce(@results + ', ', '') + convert(varchar(12),k.t1)
我明白了
(1) Люкс
(4) Полулюкс
(2) Стандарт
(6) Стандарт
(1) Стандарт
如您所见,缺少部分字符串列。我能做些什么来解决它?
【问题讨论】:
-
你应该绝对使用
nvarchar作为西里尔字符!!
标签: sql-server tsql coalesce