某个字段需要存储 长文本类型的数据,长度可变,范围不清.
varchar
最多能存储多大长度呢? 何种情况下用text
更好?
<1>.先将content字段设为varchar(255)
,则此字段只能最多存储255个字符数
package main
import "fmt"
func main() {
var str string
for i := 1; i <= 255; i++ {
str += "a"
}
fmt.Println(str)
fmt.Println(len(str))
}
输出为:
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
255
但如果写入更长的数据,则会从第255位开始,之后的都舍弃.
<2>.varchar
类型的上限是 最多能存储65535个字节的数据(而不是字符; 即64KB),因而其上限和字符集有关,如果是latin1
,则可以表示65532长度的字符数 (变长字段额外使用1或2个字节来记录实际数据长度、以及是否为NULL标识位,如果数据表只有一个varchar字段且该字段DEFAULT NULL,那么该varchar字段的最大长度为65532个字节,即65535-2-1=65532 byte)
字符集为utf-8
时,则最多存 个字符数,