如何将nvarchar 转换为 varchar ,并且确保转换后的中文不会变成乱码???谢谢,问题解决,马上结帖.

jjhlover 2005-05-30 05:13:55
如何将nvarchar 转换为 varchar ,并且确保转换后的中文不会变成乱码???谢谢,问题解决,马上结帖.

我直接用 convert(varchar,字段),表中该字段为中文.
...全文
2006 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
txqgyf 2005-06-06
  • 打赏
  • 举报
回复
cast(字段 as varchar(长度))
jjhlover 2005-06-06
  • 打赏
  • 举报
回复
谢谢参与!
jjhlover 2005-06-06
  • 打赏
  • 举报
回复
问题没有解决
jjhlover 2005-05-30
  • 打赏
  • 举报
回复
convert(varchar(2*字段长度),字段),

以上解决还是不能乱码问题???,请确认。

duanduan1122 2005-05-30
  • 打赏
  • 举报
回复
大力哥说的对!!!
因为nvarchar的一个字符不管是英文的还是中文的,都占一个unicode字符,而一个unicode字符是2个字节。varchar的一个英文字符占1个字节,一个中文占2个字节。
duanduan1122 2005-05-30
  • 打赏
  • 举报
回复
char 和 varchar
固定长度 (char) 或可变长度 (varchar) 字符数据类型。

char[(n)]

长度为 n 个字节的固定长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为 n 个字节。char 在 SQL-92 中的同义词为 character。

varchar[(n)]

长度为 n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。所输入的数据字符长度可以为零。varchar 在 SQL-92 中的同义词为 char varying 或 character varying。

注释
如果没有在数据定义或变量声明语句中指定 n,则默认长度为 1。如果没有使用 CAST 函数指定 n,则默认长度为 30。

将为使用 char 或 varchar 的对象被指派数据库的默认排序规则,除非用 COLLATE 子句另外指派了特定的排序规则。该排序规则控制用于存储字符数据的代码页。

支持多语言的站点应考虑使用 Unicode nchar 或 nvarchar 数据类型以尽量减少字符转换问题。如果使用 char 或 varchar:

如果希望列中的数据值大小接近一致,请使用 char。


如果希望列中的数据值大小显著不同,请使用 varchar。
如果执行 CREATE TABLE 或 ALTER TABLE 时 SET ANSI_PADDING 为 OFF,则一个定义为 NULL 的 char 列将被作为 varchar 处理。

当排序规则代码页使用双字节字符时,存储大小仍然为 n 个字节。根据字符串的不同,n 个字节的存储大小可能小于 n 个字符。
pengdali 2005-05-30
  • 打赏
  • 举报
回复
1、显示原来的排序规则:
select SERVERPROPERTY('Collation')


2、保持原来的排序规则:
cast(字段 as varchar(长度)) collate Chinese_PRC_CI_AS --Chinese_PRC_CI_AS为你的排序规则
jjhlover 2005-05-30
  • 打赏
  • 举报
回复
TO: pengdali(大力 V3.0)

长度多一倍,就能解决乱码问题吗?
duanduan1122 2005-05-30
  • 打赏
  • 举报
回复
nchar 和 nvarchar
nchar 是固定长度 Unicode 数据的数据类型,nvarchar 是可变长度 Unicode 数据的数据类型,二者均使用 UNICODE UCS-2 字符集。

nchar(n)

包含 n 个字符的固定长度 Unicode 字符数据。n 的值必须介于 1 与 4,000 之间。存储大小为 n 字节的两倍。nchar 在 SQL-92 中的同义词为 national char 和 national character。

nvarchar(n)

包含 n 个字符的可变长度 Unicode 字符数据。n 的值必须介于 1 与 4,000 之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度可以为零。nvarchar 在 SQL-92 中的同义词为 national char varying 和 national character varying。

注释
如果没有在数据定义或变量声明语句中指定 n,则默认长度为 1。如果没有使用 CAST 函数指定 n,则默认长度为 30。

如果希望列中所有数据项的大小接近一致,则使用 nchar。

如果希望列中数据项的大小差异很大,则使用 nvarchar。

使用 nchar 或 nvarchar 的对象被赋予数据库的默认排序规则,除非使用 COLLATE 子句赋予特定的排序规则。

SET ANSI_PADDING OFF 不适用于 nchar 或 nvarchar。SET ANSI_PADDING ON 永远适用于 nchar 和 nvarchar。

duanduan1122 2005-05-30
  • 打赏
  • 举报
回复
convert(varchar(2*字段长度),字段),

pengdali 2005-05-30
  • 打赏
  • 举报
回复
convert(varchar(长度),字段),


注:这里的长度必须是你的“字段”长度的一倍

34,875

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧