首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

char、varchar、binary和varbinary的区别与联系

char使用固定长度的空间进行存储,char(4)存储4个字符,根据编码方式的不同占用不同的字节,gbk编码方式,不论是中文还是英文,每个字符占用2个字节的空间,utf8编码方式,每个字符占用3个字节的空间。 如果需要存储的字符串的长度跟所有值的平均长度相差不大,适合用char,如MD5。 对于经常改变的值,char优于varchar,原因是固定长度的行不容易产生碎片。 对于很短的列,char优于varchar,原因是varchar需要额外一个或两个字节存储字符串的长度。 varchar保存可变长度的字符串,使用额外的一个或两个字节存储字符串长度,varchar(10),除了需要存储10个字符,还需要1个字节存储长度信息(10),超过255的长度需要2个字节来存储 例外:Myisam引擎中使用ROW_FORMAT=FIXED时,每行使用相同的空间,造成浪费 char和varchar后面如果有空格,char会自动去掉空格后存储,varchar虽然不会去掉空格,但在进行字符串比较时,会去掉空格进行比较

01

python之字符串系列

python字符串 1.序列的操作 可通过len()函数验证长度,并通过索引操作得到各个元素 例如: S=’abcd’ 字符串赋值给变量S 偏移量a对应0,以此类推 Len(S) 验证长度 4 S[0] 索引(有正向和反向) ‘a’ S[1:3] 切片(偏移量从一开始包含一到三结束不包含三) ‘bc’ S+’xyz’ 支持加号合并 ‘abcxyz’ S*3 重复创建新字符串 ‘abcabcabc’ 2.不可变性 例子中没有任何操作对原始字符串进行改变.每个字符串都被定义为新的字符串作为其结果 即不能通过对字符串某一位置进行赋值来改变字符串,但可以通过建立新的字符串并以同一个变量名对其进行赋值,python在运行过程中会清理就的对象. 例如 S=’abc’ S[0]=’z’ 希望将S字符串的第0偏移位变成z(这样操作回报错) ...error.. S=’z’+S[1:] 可以重新赋值得到新的字符串 ‘zbc’

01

从一个bug谈rtrim

本来以为得到的结果会是“战争”,但实际输出的却只有“战”。 不明所以,以为是 rtrim 的问题。查了一下,原来是自己对 rtrim 的理解有误。 rtrim 函数原型: string rtrim ( string str [, string charlist] ) 仔细看了下手册中charlist的解释: You can also specify the characters you want to strip, by means of the charlist parameter. Simply list all characters that you want to be stripped. 它的实际意思应该是:以每个字符为单位从目标字符串的右端开始查找,如果该字符在 trim 函数的第二个参数中,就将其删掉,直到当前字符不在参数列表中为止。而并非是我先前以为的:从str 的串尾去掉固定字串charlist。

02
领券