繁体   English   中英

确定nvarchar列中的varchar内容

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM