8

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

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

如果我简单地说

ALTER TABLE TableName ALTER COLUMN columnName VARCHAR(200)

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

我该如何检查?

4

2 回答 2

22

为什么不在那里然后回来看看哪些数据丢失了?

这假设列是 nvarchar(200) 开始

SELECT *
FROM TableName
WHERE columnName <> CAST(CAST(columnName AS varchar(200)) AS nvarchar(200))
于 2009-08-16T10:23:57.730 回答
1

嗯很有趣。

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

于 2009-08-16T10:19:21.737 回答