我有以下代码:
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) Стандарт
如您所见,字符串列的一部分丢失了。我该如何解决?
你varchar(12)
是太小,无法容纳你的结果,由于做MySQL(和SQL Server)计数长度VARCHAR。例如,运行以下查询:
SELECT LENGTH( 'Стандарт TWN' )
会给你20的长度!您需要增加长度,您会没事的。
SQL Fiddle显示结果:http ://sqlfiddle.com/#!9/9eecb7d/5661/0
在SQL Server中,您可能还希望考虑使用nvarchar。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句