mysql 中char类型的问题

mysql 中char类型的问题,第1张

char是一种固定长度类型,varchar则是一种可变长度的类型,它们的区别是:

char(M)类型的数据列里,每个值都占用M个

字节

,如果某个长度小于M,MySQL就会在它的

右边

用空格字符补足.(在检索 *** 作中那些填补出来的空格字符将被去掉)在varchar(M)类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节).

在MySQL中用来判断是否需要进行对据列

类型转换

规则

1、在一个

数据表

里,如果每一个数据列的长度都是固定的,那么每一个数据行的长度也将是固定的.

2、只要数据表里有一个数据列的长度的可变的,那么各数据行的长度都是可变的.

3、如果某个数据表里的数据行的长度是可变的,那么,为了节约

存储空间

,MySQL会把这个数据表里的固定长度类型的数据列转换为相应的可变长度类型.

例外:长度小于4个字符的char数据列不会被转换为varchar类型

希望对你有帮助

char 是固定长度的字符串,不足长度时会用空格补足,长度0-255;

比如char(20),如果实际数据是"123",则会自动补17个空格;

varchar 是可变长度的字符串,不足时不会补空格,超过时会自动截断,长度0-255;

text 是长文本字符串,长度0-65535

此外,还有MEDIUMTEXT,LONGTEXT等

MySQL 自己不带有 to_char 这个函数的。

你要模仿 Oracle, 写一个 MySQL 的 TO_CHAR 函数?

这个恐怕有点麻烦。

因为 Oracle 的 TO_CHAR 是可以把 日期型的, 数值型的, 转换为 字符类型。

你这个MySQL 下的 to_char , 只要转换日期呢? 还是转换 数字?


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5905146.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-07
下一篇 2023-03-07

发表评论

登录后才能评论

评论列表(0条)

保存