你说的sql server的数据类型吧?
char 定长字符型,如char(10),你实际数据是‘hello’,这时Sql Server 会自动补充空格,填满10位。varchar:可变长字符,没有上述问题,是多长就保存多长的数据。
  还有容量等其他一些区别,不过用的时候注意前面所说就行了。

解决方案 »

  1.   

    在数据库设计中,如果字段长度大体能够确定,建议用char,因为Varchar类型在数据库查询中效率不如char类型高。
      

  2.   

    又有人问这个问题,同意 jjcccc
      

  3.   

    其实jjcccc都说完了
    我也来随便说说了 (-:
    varchar最大的用处是可以避免使用text等类型,比如一个varchar(7500),可以容纳7500个字符,大多数情况下用不着可以支持2G的text(是不是2G记不到了哈)
    而且假设你只有5个字符,也只占5个字符的空间,比较科学的说
      

  4.   

    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 个字符。
      

  5.   

    另外,如果要对中文支持的好,就请用nvarchar吧,这样不至于一个汉字占两位了!