varchar、int与char的区别

本文探讨了MySQL中Char和VarChar两种数据类型的特性。Char类型存储定长字符串,适合快速存取,但可能浪费空间;VarChar则存储变长字符串,节省空间但存取较慢。在设计数据库时,应根据性能需求和空间效率权衡选择。同时,文章提到了varchar(50)中的50代表最多字符数,而int(20)中的20影响的是显示宽度而非存储占用。


char的特点

  • char表示定长字符串,长度是固定的;
  • 如果插入数据的长度小于char的固定长度时,则用空格填充;
  • 因为长度固定,所以存取速度要比varchar快很多,甚至能快50%,但正因为其长度固定,所以会占据多余的空间,是空间换时间的做法;
  • 对于char来说,最多能存放的字符个数为255,和编码无关

varchar的特点

  • varchar表示可变长字符串,长度是可变的;
  • 插入的数据是多长,就按照多长来存储;
  • varchar在存取方面与char相反,它存取慢,因为长度不固定,但正因如此,不占据多余的空间,是时间换空间的做法;
  • 对于varchar来说,最多能存放的字符个数为65532

总之,结合性能角度(char更快)和节省磁盘空间角度(varchar更小),具体情况还需具体来设计数据库才是妥当的做法。

varchar(50)中50的涵义
        最多存放50个字符,varchar(50)和(200)存储hello所占空间一样,但后者在排序时会消耗更多内存,因为order by col采用fixed_length计算col长度(memory引擎也一样)。在早期 MySQL 版本中, 50 代表字节数,现在代表字符数。

int(20)中20的涵义
        是指显示字符的长度。20表示最大显示宽度为20,但仍占4字节存储,存储范围不变;

        不影响内部存储,只是影响带 zerofill 定义的 int 时,前面补多少个 0,易于报表展示

### intchar varchar 数据类型的区别 在数据库设计中,选择合适的数据类型对于优化存储空间提高查询性能至关重要。以下是 `int`、`char` `varchar` 这三种数据类型的详细对比: #### 1. 数据类型定义 - **int**:用于存储整数值,适合固定范围的数值数据[^5]。其存储大小通常为4字节(32位),可以表示从 -2,147,483,648 到 2,147,483,647 的范围。 - **char**:用于存储固定长度的字符串,适合短且长度固定的字段[^5]。例如,如果定义了一个 `CHAR(10)` 字段,则无论实际存储的字符数量是多少,都会占用10个字符的空间。 - **varchar**:用于存储可变长度的字符串,适合长度不固定的字段。 `char` 不同,`varchar` 只会占用实际存储字符所需的空间,外加1或2个字节来记录字符串长度。 #### 2. 存储空间 - **int**:存储空间固定为4字节,存储的具体值无关。 - **char**:无论实际存储的字符数量是多少,都会按照定义的长度分配存储空间。例如,`CHAR(10)` 即使只存储一个字符,也会占用10个字符的空间[^5]。 - **varchar**:存储空间是动态的,仅占用实际存储字符所需的字节数,再加上1或2个字节用于记录长度[^2]。 #### 3. 性能比较 - **int**:由于其固定长度简单的数据结构,`int` 类型的查询索引性能通常较高。 - **char**:因为 `char` 是固定长度的,所以在存取时速度较快,尤其是在需要对齐或填充的情况下[^3]。 - **varchar**:由于长度不固定,`varchar` 在存取时相对较慢,因为它需要额外的计算来确定每个字符串的实际长度[^2]。 #### 4. 使用场景 - **int**:适用于需要存储整数的场景,如用户ID、计数器等。 - **char**:适用于存储长度固定且较短的文本,如邮政编码、性别(`M`/`F`)等[^4]。 - **varchar**:适用于存储长度变化较大的文本,如姓名、地址等[^4]。 #### 示例代码 以下是一个简单的 MySQL 表示例,展示如何使用这三种数据类型: ```sql CREATE TABLE example_table ( id INT PRIMARY KEY AUTO_INCREMENT, gender CHAR(1), name VARCHAR(50) ); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值