确定nvarchar列中的varchar内容

时间:2009-08-16 10:16:57

标签: sql sql-server tsql varchar nvarchar

我有一堆NVARCHAR列,我怀疑它们在VARCHAR列中包含完全可存储的数据。但是,我不能只是将列的类型更改为VARCHAR并希望最好,我需要进行某种检查。

我想进行转换,因为数据是静态的(将来不会改变)并且列被索引并且与实际(nvarchar)索引相比将受益于更小的(varchar)索引。

如果我只是说

ALTER TABLE TableName ALTER COLUMN columnName VARCHAR(200)

然后我不会收到错误或警告。 Unicode数据将被截断/丢失。

如何查看?

2 个答案:

答案 0 :(得分:22)

为什么不在那里投反对,看看哪些数据丢失了?

这假设列以

开头的nvarchar(200)
SELECT *
FROM TableName
WHERE columnName <> CAST(CAST(columnName AS varchar(200)) AS nvarchar(200))

答案 1 :(得分:1)

嗯很有趣。

我不确定您是否可以在SQL查询中执行此操作。你是否乐于在代码中做到这一点?如果是这样,您可以获取所有记录,然后遍历字符串中的所有字符并检查。但是男人这是一个缓慢的方式。