我有一堆NVARCHAR列,我怀疑它们在VARCHAR列中包含完全可存储的数据。但是,我不能只是将列的类型更改为VARCHAR并希望最好,我需要进行某种检查。
我想进行转换,因为数据是静态的(将来不会改变)并且列被索引并且与实际(nvarchar)索引相比将受益于更小的(varchar)索引。
如果我只是说
ALTER TABLE TableName ALTER COLUMN columnName VARCHAR(200)
然后我不会收到错误或警告。 Unicode数据将被截断/丢失。
如何查看?
答案 0 :(得分:22)
为什么不在那里投反对,看看哪些数据丢失了?
这假设列以
开头的nvarchar(200)SELECT *
FROM TableName
WHERE columnName <> CAST(CAST(columnName AS varchar(200)) AS nvarchar(200))
答案 1 :(得分:1)
嗯很有趣。
我不确定您是否可以在SQL查询中执行此操作。你是否乐于在代码中做到这一点?如果是这样,您可以获取所有记录,然后遍历字符串中的所有字符并检查。但是男人这是一个缓慢的方式。