zoukankan      html  css  js  c++  java
  • Mysql char(10) 与 varchar(10)的区别

    DROP TABLE test_string;
    
    CREATE TABLE test_string (col_char CHAR(10),
    col_varchar VARCHAR(10));
    
    INSERT INTO `test_string` VALUES ('mysql', 'mysql');

    在创建数据库表时,为了给一个string类型的数据定义一个数据库中的数据类型,一般参考的都是char或varchar,但这两者的选择有时候让人很纠结,现总结一下两者的区别:

    (1)CHAR的长度是固定的,而VARCHAR的长度是可以变化的。

    比如,存储字符串“mysql",对于CHAR(10),表示你存储的字符串将占10个字节(包括5个空字符)。

    而同样的VARCHAR (10)则只占用5个字节的长度,10只是其最大值限制,当你存储的字符小于10时,按实际长度存储。

    (2)CHAR的效率比VARCHAR的效率稍高。

    取数据的时候,char类型的要用trim()去掉多余的空格,而varchar是不需要的。

    尽管如此,char的存取数度还是要比varchar要快得多,因为其长度固定,方便程序的存储与查找;

    但是,char也为此付出的是空间的代价,因为其长度固定,所以难免会有多余的空格占位符占据空间,可谓是以空间换取时间效率,而varchar是以空间效率为首位的。

    (3)CHAR(10)若输入数据的字符数小于10,则系统自动在其后添加空格来填满设定好的空间。若输入的数据过长,将会截掉其超出部分。VARCHAR(10)数据类型的存储长度为实际数值长度。

    (4)char的存储方式是,对英文字符(ASCII)占用1个字节,对一个汉字占用两个字节;而varchar的存储方式是,对每个英文字符占用2个字节,汉字也占用2个字节,两者的存储数据都非unicode的字符数据。

    Good Good Study, Day Day Up.

    顺序 选择 循环 总结

  • 相关阅读:
    Mac OS X下Maven的安装与配置
    [MAC Eclipse] Eclipse for MAC 中文乱码的解决办法
    The type javax.servlet.http.HttpServletRequest cannot be resolved.
    IOS基础:深入理解Objective-c中@class的含义
    NSJSONSerialization-JSON数据与NSDictionary和NSArray之间的转化
    真机测试时的错误:No matching provisioning profiles found
    转帖Jmeter中的几个重要测试指标释义
    Spring集成log4j日志管理
    Log4J日志配置详解
    使用Redis的理由
  • 原文地址:https://www.cnblogs.com/Braveliu/p/11576769.html
Copyright © 2011-2022 走看看