,初始为函数参数in_string值 DECLARE tmp_len SMALLINT DEFAULT 0;#tmp_str的长度 DECLARE tmp_char VARCHAR(2) charset...VARCHAR(65534) charset gbk DEFAULT '';#结果字符串 DECLARE tmp_cc VARCHAR(2) charset gbk DEFAULT '';#拼音字符,存放单个汉字对应的拼音首字符...SET tmp_str = in_string;#初始化,将in_string赋给tmp_str SET tmp_len = LENGTH(tmp_str);#初始化长度 WHILE tmp_len...> 0 DO #如果被计算的tmp_str长度大于0则进入该while SET tmp_char = LEFT(tmp_str,1);#获取tmp_str最左端的首个字符,注意这里是获取首个字符,该字符可能是汉字...SET tmp_cc = tmp_char;#左端首个字符赋值给拼音字符 IF LENGTH(tmp_char)>1 THEN#判断左端首个字符是多字节还是单字节字符,要是多字节则认为是汉字且作以下拼音获取
疑问: mysql的字段,unsigned int(4), 和unsinged int(5), 能存储的数值范围是否相同。如果不同,分别是多大?...答: 无论是int(4), int(5), 存储的都是4字节无符号整数, 也就是0~2^32。。但是,当数字不足4位或5位时,前面会用0补齐。...MySQL支持选择在该类型关键字后面的括号内指定整数值的显示宽度(例如,INT(4))。 该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度。...显示宽度并不限制可以在列内保存的值的范围,也不限制超过列的指定宽度的值的显示。 也就是说,int的长度并不影响数据的存储精度,长度只和显示有关
提问: mysql的字段,unsigned int(3), 和unsinged int(6), 能存储的数值范围是否相同。如果不同,分别是多大?...如果你的答案和上面的一致,恭喜你和我犯了一样的错误。...查下手册,解释是这样的: MySQL还支持选择在该类型关键字后面的括号内指定整数值的显示宽度(例如,INT(4))。该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度。...显示宽度并不限制可以在列内保存的值的范围,也不限制超过列的指定宽度的值的显示。...也就是说,int的长度并不影响数据的存储精度,长度只和显示有关,为了让大家看的更清楚,我们在上面例子的建表语句中,使用了zerofill。
在MySQL5.7里默认 innodb_large_prefix=1 解除了767bytes长度限制,但是单列索引长度最大还是不能超过3072bytes。...https://dev.mysql.com/doc/refman/8.0/en/create-index.html varchar(n)占用几个字节跟字符集有关系: 字符类型若为gbk,每个字符占用2个字节...所以我们经常会见到把字段设置成varchar(255)长度的,在utf8字符集下这个是最大不超过767bytes的长度了,但是并不是一定要设置成varchar(255),还是要根据业务设置每个字段的长度...解决办法 可以直接去改字段的长度,或者说,把索引的字段取消掉一些,但是这样改对表本身是不友好的。 通过限定字段的前n个字符为索引,可以通过衡量实际的业务中数据中的长度来取具体的值。...,这个就是我们说的前缀索引 修改单个索引的最大长度 修改索引限制长度需要在my.ini配置文件中添加以下内容,并重启: #修改单列索引字节长度为767的限制,单列索引的长度变为3072 innodb_large_prefix
utf8 结论: 1、int:固定占用4个字节 2、不同字符集占用字节数不同: 3、latin1:2个字节 4、utf8:3个字节 5、是否为空占用1个字节,not null不占用字节 6、变长字段需要记录长度占用...2个字节 7、索引长度计算公式:varchar(20)*3+1+2=63
参考: http://dinglin.iteye.com/blog/1681332 单列索引的长度的限制 (5.6里面默认不能超过767bytes,5.7不超过3072bytes): 起因是...255×4>767, 于是增加了一个参数叫做 innodb_large_prefix # 256的由来: 只是因为char最大是255,所以以前的程序员以为一个长度为255的index就够用了,...--- by 阿里-丁奇 在MySQL5.6里默认 innodb_large_prefix=0 限制单列索引长度不能超过767bytes 官网文档:https://dev.mysql.com/doc...在MySQL5.7里默认 innodb_large_prefix=1 解除了767bytes长度限制,但是单列索引长度最大还是不能超过3072bytes 联合索引的长度的限制 (不能超过3072bytes...idx_a的长度为:255*3*5= 3825 bytes ,大于最大值 3072 bytes 为什么3072,原因如下: 我们知道InnoDB一个page的默认大小是16k。
在做 iPhone 应用的时候,给用户推送信息的时候,最多只能 255 个字符。...如果传送的汉字是使用默认的 json_encode 来编码的话,这样的编码出来的是 unicode 编码的,也就是\u的编码,一个汉字是 \u+4个字符,共占 6 个字符,这样扣除其他一些信息,差不多只能...所以不能直接使用 json_encode 方法来编码,解决方案是:先把汉字 urlencode,然后再使用 json_encode,最后再次使用urldecode 来解码,这样编码出来的 JSON 数组中的汉字就不会出现
只扫描索引而无需回表的优点: 1.索引条目通常远小于数据行大小,只需要读取索引,则mysql会极大地减少数据访问量。...(innodb的二级索引在叶子节点中保存了行的主键值,所以如果二级主键能够覆盖查询,则可以避免对主键索引的二次查询) 覆盖索引必须要存储索引列的值,而哈希索引、空间索引和全文索引不存储索引列的值,所以mysql...当发起一个索引覆盖查询时,在explain的extra列可以看到using index的信息 覆盖索引的坑:mysql查询优化器会在执行查询前判断是否有一个索引能进行覆盖,假设索引覆盖了where条件中的字段...,但不是整个查询涉及的字段,mysql5.5和之前的版本也会回表获取数据行,尽管并不需要这一行且最终会被过滤掉。...2.mysql不能在索引中执行LIke操作。mysql能在索引中做最左前缀匹配的like比较,但是如果是通配符开头的like查询,存储引擎就无法做比较匹配。
前两天同事提了一个问题,MySQL 5.7 中给某张表字段增加一个单键值索引,提示了如下错误, 一些背景信息: 表设置的字符集,utf8mb4 。 表的存储引擎,MyISAM 。...我们知道,MySQL 和 Oracle 在索引上最大的一个区别,就是索引存在长度的限制。如果是超长键值,可以支持创建前缀的索引,顾名思义,取这个字段的前多少个字符/字节作为索引的键值。...MySQL 官方手册索引的章节提到了,前缀索引长度限制是和引擎相关的,如果用的是 InnoDB ,前缀上限是 767 字节,当启用 innodb_large_prefix 时,上限可以达到 3072 字节...utf8mb4 是 MySQL 5.5.3 之后增加的编码,mb4 就是 most bytes 4 的意思,专门用来兼容四字节的 unicode ,utf8mb4 是 utf8 的超集。...因此,任何不在基本多文种平面的 Unicode 字符,都无法使用 MySQL 的 utf8 字符集存储,这就包括 Emoji 表情( Emoji 是一种特殊的 Unicode 编码,常见于手机上),和很多不常用的汉字
创建数据库的时候发现一个问题: 改变 length 的值, 不能影响到实际的存储长度!...秉着好奇心, 打开了 google ~ 引入大神的解答. mysql 在建表的时候 int 类型后的长度代表什么? 是该列允许存储值的最大宽度吗?...所以我在网上查阅了一些资料, 也仔细的看了 mysql 手册关于 int data type 的说法. 以下是每个整数类型的存储和范围 (来自 mysql 手册) ?...mysql 我们看到现在我的 number 字段, 长度 (M)=5, 属性 =UNSIGNED ZEROFILL(无符号, 用 0 来填充位数), 设置这个属性后我往表时插入数据, 系统会自动把 number...mysql 手册上还有这么一句话 "当 mysql 为某些复杂的联结 (join) 生成临时表时,你可能会遇到问题,因为在这种情况下,mysql 信任地认为所有的值均适合原始的列宽度".
4.不同的字符集,一个字符占用的字节数不同。latin1编码的,一个字符占用1个字节,gbk编码的,一个字符占用2个字节,utf8编码的,一个字符占用3个字节。...utf8mb4是一个字符占4个字节 5.使用explain语句查询到的key_len字段,可以适用于上面的计算规则,可以看到查询是否使用到了联合索引 6.mysql优化器会对条件中的 and的前后顺序根据多列索引顺序自动纠正过来...通过索引的长度查看下面sql语句是否使用到了索引 CREATE TABLE `index_test` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT...+--------------------+--------------------+---------+------+------+----------+-------------+ key_len的长度是
0.一个汉字占多少字节与编码有关: UTF-8:一个汉字=3个字节 GBK:一个汉字=2个字节 1.varchar(n),char(n)表示n个字符...,无论汉字和英文,MySQL都能存入n个字符,仅是实际字节长度有所区别 2.MySQL指定整数值的显示宽度(例如,INT(4))。...该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度。显示宽度并不限制可以在列内保存的值的范围,也不限制超过列的指定宽度的值的显示。 ...建立这个长度是为了告诉MYSQL数据库我们这个字段的存储的数据的宽度为5位数, 当然如果你不是5位数(只要在该类型的存储范围之内)MYSQL也能正常存储 在Java中一共有八种基本数据类型。...的取值范围为-128~127,占用1个字节(-2的7次方到2的7次方-1) short的取值范围为-32768~32767,占用2个字节(-2的15次方到2的15次方-1) int的取值范围为(-2147483648
大家好,又见面了,我是你们的朋友全栈君。 您可以使用SUBSTRING()MySQL来限制字符串的长度。...创建表的查询如下mysql> create table limitLengthOfLongTextDemo -> ( -> sentence LONGTEXT -> ); 使用insert命令在表中插入一些记录...查询如下mysql> insert into limitLengthOfLongTextDemo values(‘This is the introduction to MySQL’); mysql>...limitLengthOfLongTextDemo values(‘Java is an Object Oriented Programming Language’); 使用select语句显示表中的所有记录...Object Oriented Programming Language | +——————————————————+ 3 rows in set (0.00 sec) 这是获取给定值字符的查询
mysql 在DDL 权威指南 5.6 官方文档 :verision :https://dev.mysql.com/doc/refman/5.6/en/innodb-online-ddl-operations.html...对于VARCHAR大小为0到255个字节的列,需要一个长度的字节来编码该值。对于VARCHAR 大小为256字节或更大的列,需要两个长度的字节。...就地 ALTER TABLE不支持增加 VARCHAR列,从小于256个字节到等于或大于256个字节的大小。在这种情况下,所需的长度字节数从1更改为2,仅表副本(ALGORITHM=COPY)支持。...注意 一个的字节长度VARCHAR列是依赖于字符集的字节长度 。 减少VARCHAR使用就地尺寸ALTER TABLE不被支持。减小VARCHAR 大小需要表副本(ALGORITHM=COPY)。...总结 在数据量很大的时候,varchar通过Online DDL做到快速进行更改字段长度。但是前提条件就是不会进行锁表和copy数据的过程。 这个前提条件就是数据库的支持5.7及5.7以上。
MySQL中还会对索引键的长度有限制?...、BLOB),前缀会按照字节个数计算,因此,当对非二进制的字符串列明确前缀长度的时候,需要考虑多字节字符集的因素, P.S. https://dev.mysql.com/doc/refman/5.6.../en/create-index.html 前缀的长度限制,是和存储引擎相关的。...再看一下《MySQL 5.7 Reference Manual》,相同章节中,多了这段描述,是说当使用CREATE INDEX时,如果指定的索引前缀长度超过了列定义的长度上限,则会出现以下两种场景, 非唯一索引...,一个单键值索引,如果达到这长度,就得考虑下索引字段的选择是否合理了,当然如果是几个字段组成的复合索引,达到这个长度,合理不合理,就得实际评估了。
最近,在工作中遇到了MySQL中如何存储长度较长的字段类型问题,于是花了一周多的时间抽空学习了一下,并且记录下来。...MySQL大致的逻辑存储结构在这篇文章中有介绍,做为基本概念:InnoDB 逻辑存储结构 注:文中所指的大数据指的是长度较长的数据字段,包括varchar/varbinay/text/blob。...此处的值为64764,加上前缀768正好是65532。(注意一点,虽然表示BLOB长度的是8字节,实际只有4个字节能使用,所有对于BLOB字段,存储数据的最大长度为4GB。)...将列放入外部存储页的标准 当一行中的数据不能在数据页中放下,需要申请外部存储页时,MySQL需要决定将哪一列的数据放到外部存储页,遵循的规则如下: 长度固定的字段不会被放到外部存储页(int、char(...N)等) 长度小于20字节的字段不会被放到外部存储页。
在mysql中的group_concat函数默认支持的最大字符数为1024。 当你使用group_concat函数时,超出第1024字符的字符会全部丢失。 今天就被这个问题搞了一两个小时。...获得group_concat的最大长度 SELECT @@global.group_concat_max_len; 或者 show variables like "group_concat_max_len..."; 一看自己的mysql中group_concat的最大限制 发现等于1024 解决方法: 1.使用sql设置group_concat的最大长度 SET GLOBAL group_concat_max_len...=102400; SET SESSION group_concat_max_len=102400; 但是这种方式在重启mysql后就无效。...2.在MySQL配置文件中my.conf或my.ini中添加: #[mysqld] group_concat_max_len=102400 然后重启mysql服务
前言 有5个库,每个库里面的表结构一样,现在需要修改某个字段的长度,操作的时候记得要选择非业务时间段,当然也可以直接使用存储过程来搞。...WHERE TABLE_SCHEMA='scrm_wechat_1' AND COLUMN_NAME IN ('resource_url') 执行SQL 直接执行或者通过SQL脚本都可以,我直接执行的
先说结论:在MySQL 5.5及以上版本中,可以。 需求分析 目前互联网公司数据持久化中间件都选了MySQL。 在实际应用中,有时会遇到需要存储大量汉字的需求。...MySQL VARCHAR与汉字存储 在MySQL中,VARCHAR类型的字段用于存储可变长度的字符串,长度可以是0到65,535之间的值,VARCHAR的有效最大长度取决于最大行大小(65,535字节...但是在MySQL中,VARCHAR类型的长度限制是按照字符数来计算的,而不是字节数。这意味着,无论存储的是英文还是中文,只要字符数不超过定义的长度,就可以存储。...从数据库版本角度看,在MySQL 5.0及以上版本中,VARCHAR类型的最大长度可以达到65535个字符,但由于需要额外1到2个字节来存储数据长度,实际可存储的最大字符数为65533个字符。...因此,如果您的MySQL版本是5.0或以上,那么VARCHAR(6)可以存储的字符数实际上是6个,而不是2个中文汉字。
大家好,又见面了,我是你们的朋友全栈君。...gbk2312 编码范围共94区, 0-55区为一级汉字, 是按照拼音顺序排列的, 可以按照编码区间确定汉字的拼音, 但是 56 区以后是按笔画顺序排列的, 所以只能用对照表来确定拼音 鉴于目前我找不到现成的代码..., 固整理了一份, 测试可用. /** * PHP 汉字转拼音 * echo CUtf8_PY::encode('字符串'); //编码为拼音首字母 * echo CUtf8_PY::encode...|豋:deng|鄧:deng|鐙:deng|隥:deng|哣:deo|地:di|第:di|底:di|低:di|敌:di|抵:di|滴:di|帝:di|递:di|嫡:di|弟:di|缔:di|堤:di|的:...dao|薵:dao|虭:dao|衜:dao|衟:dao|裯:dao|軇:dao|醻:dao|釖:dao|陦:dao|陶:dao|隝:dao|隯:dao|魛:dao|鱽:dao|鳥:dao|鸟:dao|的:
领取专属 10元无门槛券
手把手带您无忧上云