【问题标题】:SQL Server : coalesce, the part of string is missingSQL Server:合并,字符串的一部分丢失
【发布时间】: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


【解决方案1】:

由于 MySQL(和 SQL Server)计算 varchar 长度的方式,您的 varchar(12) 太小而无法保存您的结果。例如,运行这个查询:

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

会给你20的长度!你需要增加长度,你会没事的。

SQL Fiddle 显示结果:http://sqlfiddle.com/#!9/9eecb7d/5661/0

在 SQL Server 中,您可能还希望考虑使用 nvarchar。

【讨论】:

  • 实际上是 Microsoft SQL Server(不是 MySQL)
  • 哎呀。 :)。由于 SQL Server 缺乏 UTF8 支持,您可能会看到基于 db.xml 中的默认编码的相同行为。由于您没有使用 nvarchar,我希望这仍然是同一个问题。确保使用 UTF16。
猜你喜欢
  • 2017-07-13
  • 1970-01-01
  • 2011-02-21
  • 2011-03-23
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多