[英]Determine varchar content in nvarchar columns
我有一堆NVARCHAR列,我怀疑在VARCHAR列中包含完全可存储的数据。 但是,我不能只是将列的类型更改为VARCHAR并希望最好,我需要进行某种检查。
我想进行转换,因为数据是静态的(将来不会改变)并且列被索引并且与实际(nvarchar)索引相比将受益于更小的(varchar)索引。
如果我只是说
ALTER TABLE TableName ALTER COLUMN columnName VARCHAR(200)
那我就不会收到错误或警告。 Unicode数据将被截断/丢失。
我该如何检查?
为什么不在那里投回去看看哪些数据丢失了?
这假设列的开头是nvarchar(200)
SELECT *
FROM TableName
WHERE columnName <> CAST(CAST(columnName AS varchar(200)) AS nvarchar(200))
嗯有趣。
我不确定你是否可以在SQL查询中做到这一点。 你是否乐于在代码中做到这一点? 如果是这样,您可以获取所有记录,然后遍历字符串中的所有字符并检查。 但是男人这是一个缓慢的方式。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.