2015-06-13 40 views
1

我有這樣的代碼:SQL服務器:合併,字符串的部分缺失

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) Стандарт 

正如你所看到的字符串列的部分缺失。我能做些什麼來解決它?

+1

你應該**絕對**使用西里爾字符'nvarchar'! –

回答

4

由於MySQL(和SQL Server)計數varchar的長度,因此您的varchar(12)太小而無法保存結果。例如,運行此查詢:

SELECT LENGTH('Стандарт TWN') 

會給你20的長度!你需要增加長度,你會沒事的。

SQL小提琴顯示結果:http://sqlfiddle.com/#!9/9eecb7d/5661/0

在SQL Server中,你不妨考慮使用nvarchar的爲好。

+1

它實際上是Microsoft ** SQL Server **(不是MySQL) –

+1

哎呀。 :)。由於SQL Server缺少對UTF8的支持,因此您可能會看到基於db中缺省編碼的相同行爲。既然你沒有使用nvarchar,我預計這仍然是一個問題。確保你使用UTF16。 –