关于MySQL中的一些极限值的初步验证纠错
发表于:2024-10-02 作者:千家信息网编辑
千家信息网最后更新 2024年10月02日,晚上从珠江边回来之后,看到一篇文章说,MySQL有几个极限值,一个表的字段最多只有1017个,我看了以后表示怀疑。怎么快速验证呢,我看到文章的时候已经11点了,只有不到1个小时的时间来验证了。我想不能
千家信息网最后更新 2024年10月02日关于MySQL中的一些极限值的初步验证纠错晚上从珠江边回来之后,看到一篇文章说,MySQL有几个极限值,一个表的字段最多只有1017个,我看了以后表示怀疑。怎么快速验证呢,我看到文章的时候已经11点了,只有不到1个小时的时间来验证了。我想不能通过手工的方式来做,写个简单的脚本,能实现功能即可。
于是三下五除二,我写了下面的简单shelll脚本,跑一个循环,批量生成表结构信息。
首先我尝试的是int数据类型,脚本如下:
new=$1
echo 'drop table if exists test_new;' > aaa.sql
echo 'create table test_new(' >> aaa.sql
echo 'col1 int' >> aaa.sql
for ((i=2;i<=new;i++))
do
echo ,col_$i int
done >> aaa.sql
echo ');' >> aaa.sql
mysql testmysql test -e "show tables"
调用的时候只需要输入最大值即可。
比如,sh test.sh 1017发现确实如此,如果有107个int型字段是没有问题的,1018会抛出下面的错误。
# sh test.sh 1018
ERROR 1117 (HY000) at line 2: Too many columns
+----------------+
| Tables_in_test |
+----------------+
| test |
| test_data |
+----------------+
可见正如这位网友所说1017个字段,对于int型确实如此。
再进一步,我可以测试varchar类型,比如指定为varchar(20)
脚本略作修改
new=$1
echo 'drop table if exists test_new;' > aaa.sql
echo 'create table test_new(' >> aaa.sql
echo 'col1 varchar(20)' >> aaa.sql
for ((i=2;i<=new;i++))
do
echo ,col_$i varchar\(20\)
done >> aaa.sql
echo ');' >> aaa.sql
mysql testmysql test -e "show tables"
结果发现,1017个字段显然不行,怎么测试边界呢,我们可以使用二分法来快速迭代,比如1017不可以,我可以尝试500,如果500可以就尝试750,否则尝试250,以此类推。
很快得到了边界值,如果都是varchar(20),边界值是383
[root@oel642 ~]# sh aa.sql 384
ERROR 1118 (42000) at line 2: Row size too large (> 8126). Changing some columns to TEXT or BLOB may help. In current row format, BLOB prefix of 0 bytes is stored inline.
+----------------+
| Tables_in_test |
+----------------+
| test |
| test_data |
+----------------+
显然可以充分印证上面的结论还是不够严谨的,而至于细节的原因我们可以继续深入,后续继续分析下。
同理我们可以2分钟内模拟下表名的最大长度,我们知道MySQL里指定的最大长度是64,我们可以使用lpad来实现。
生成64位的表名。
mysql> select lpad('a',64,'a');
+------------------------------------------------------------------+
| lpad('a',64,'a') |
+------------------------------------------------------------------+
| aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa |
+------------------------------------------------------------------+
1 row in set (0.00 sec)
mysql> create table aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa (id int);
Query OK, 0 rows affected (0.09 sec)
都不用迭代,只需要补充一个a就可以了。
mysql> create table aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa (id int);
ERROR 1059 (42000): Identifier name 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa' is too long
于是三下五除二,我写了下面的简单shelll脚本,跑一个循环,批量生成表结构信息。
首先我尝试的是int数据类型,脚本如下:
new=$1
echo 'drop table if exists test_new;' > aaa.sql
echo 'create table test_new(' >> aaa.sql
echo 'col1 int' >> aaa.sql
for ((i=2;i<=new;i++))
do
echo ,col_$i int
done >> aaa.sql
echo ');' >> aaa.sql
mysql test
调用的时候只需要输入最大值即可。
比如,sh test.sh 1017发现确实如此,如果有107个int型字段是没有问题的,1018会抛出下面的错误。
# sh test.sh 1018
ERROR 1117 (HY000) at line 2: Too many columns
+----------------+
| Tables_in_test |
+----------------+
| test |
| test_data |
+----------------+
可见正如这位网友所说1017个字段,对于int型确实如此。
再进一步,我可以测试varchar类型,比如指定为varchar(20)
脚本略作修改
new=$1
echo 'drop table if exists test_new;' > aaa.sql
echo 'create table test_new(' >> aaa.sql
echo 'col1 varchar(20)' >> aaa.sql
for ((i=2;i<=new;i++))
do
echo ,col_$i varchar\(20\)
done >> aaa.sql
echo ');' >> aaa.sql
mysql test
结果发现,1017个字段显然不行,怎么测试边界呢,我们可以使用二分法来快速迭代,比如1017不可以,我可以尝试500,如果500可以就尝试750,否则尝试250,以此类推。
很快得到了边界值,如果都是varchar(20),边界值是383
[root@oel642 ~]# sh aa.sql 384
ERROR 1118 (42000) at line 2: Row size too large (> 8126). Changing some columns to TEXT or BLOB may help. In current row format, BLOB prefix of 0 bytes is stored inline.
+----------------+
| Tables_in_test |
+----------------+
| test |
| test_data |
+----------------+
显然可以充分印证上面的结论还是不够严谨的,而至于细节的原因我们可以继续深入,后续继续分析下。
同理我们可以2分钟内模拟下表名的最大长度,我们知道MySQL里指定的最大长度是64,我们可以使用lpad来实现。
生成64位的表名。
mysql> select lpad('a',64,'a');
+------------------------------------------------------------------+
| lpad('a',64,'a') |
+------------------------------------------------------------------+
| aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa |
+------------------------------------------------------------------+
1 row in set (0.00 sec)
mysql> create table aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa (id int);
Query OK, 0 rows affected (0.09 sec)
都不用迭代,只需要补充一个a就可以了。
mysql> create table aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa (id int);
ERROR 1059 (42000): Identifier name 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa' is too long
字段
脚本
尝试
最大
边界
面的
验证
只有
时候
类型
长度
测试
生成
迭代
极限
极限值
不行
严谨
三下五除二
以此类推
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库课后作业
职业院校劳务派遣软件开发
网络安全外网文献
国标服务器 音视频
2016重庆楼盘销售数据库
网络安全事件发生时的风险增
个人软件开发创新服务
w7服务器管理器系统下载
淄博市高新区网络安全培训基地
账号的数据库结构
数据库设计阶段与任务
计算机数据库考试操作
手机版空岛战争服务器推荐
拟南芥基因的数据库
洛阳星航软件开发有限公司
gta5无法连接r星服务器
计算机网络技术主要考什么证
徐州软件开发开发商
服务器中间件应用场景
网络安全更重要一辩稿
如何卸载速达数据库和软件
棋牌服务器 开源
iscsi服务器挂载磁盘阵列
网络安全监管不力的后果
连接服务器出现问题
天融信防火墙日志服务器设置
文水县网络安全
城阳区分销软件开发哪家做的好
网络技术初级证
广州软件开发培训班