mysql floor 不准确_MYSQL的floor出现报错如何解决

MYSQL的floor出现报错如何解决

发布时间:2020-06-02 17:30:49

来源:51CTO

阅读:159

作者:三月

不知道大家之前对类似MYSQL的floor出现报错如何解决的文章有无了解,今天我在这里给大家再简单的讲讲。感兴趣的话就一起来看看正文部分吧,相信看完MYSQL的floor出现报错如何解决你一定会有所收获的。

利用语句网上一搜一大堆,我就不再细说了,先根据一个语句上个总结图片吧:

624704b5db9c3cc2fe6fa539118f9154.png

806c21190871911b0f5cc7e71949e56f.png

先把rand函数说一下,下面会用到。

语句中的floor(rand(0)*2)是什么意思?是为了产生一个不唯一的且能会出现重复的数字。rand()函数产生的数会随机产生0到1的小数,而加上参数变成rand(0)的时候,会产生一个确定的小数(我的理解)可能有些绕, 所以我们看一下执行语句:

rand()函数执行2次结果,:

22fa5098cca66b46effd017a940a6480.png

bd9e0fdc65e4116a8e03319dcd7f707c.png

加了参数执行2次的结果:

624704b5db9c3cc2fe6fa539118f9154.png   

624704b5db9c3cc2fe6fa539118f9154.png

ac61f16f970f1e4d2d10292001821ffc.png

e1be1a7df7ff8e4013ed37a3d408710c.png

所以,rand(0)是为了得到一个确定的数,也就是执行第几次就是什么数据(我自己的理解),而*2再floor是为了得到唯一的整数数据,不然小数太长了,想找到个重复的数就太难了。。除此之外你乘大于等于2的什么数都行,当然也不能太大,比如9999999999999。要大于等于2是因为,小于2,floor(rand(0)*2)会变成0,不会不唯一,数太大,,没有那么多数据能让你查到重复。。。

再说报错,报了什么错呢,是主键重复,为什么会主键重复呢?这就group by 和 count(*)有关了,我们先看count(*)和group by组合一起的效果

624704b5db9c3cc2fe6fa539118f9154.png

4238d2eb464cc748b29565b54c366862.png

结果会显示每个列的次数,而这个列的内容,是唯一的主键。而在查询过程中,是先建立一张虚拟表,一行一行插入的,而插入时已经有重复主键了,那么,就会报错。当然,可能会问了,重复时,count(*)就加1了,为什么会主键重复呢?这就和rand()函数有关了,官方文档中提到,rand()函数在进行GROUP BY查询时会被计算多次,这里列举参考文档的解释,我觉得说的很清楚:

1.查询前默认会建立空虚拟表

2.取第一条记录,执行floor(rand(0)*2),发现结果为0(第一次计算),查询虚拟表,发现0的键值不存在,则floor(rand(0)*2)会被再计算一次,结果为1(第二次计算),插入虚表,这时第一条记录查询完毕

3.查询第二条记录,再次计算floor(rand(0)*2),发现结果为1(第三次计算),查询虚表,发现1的键值存在,所以floor(rand(0)*2)不会被计算第二次,直接count(*)加1,第二条记录查询完毕

4.查询第三条记录,再次计算floor(rand(0)*2),发现结果为0(第4次计算),查询虚表,发现键值没有0,则数据库尝试插入一条新的数据,在插入数据时floor(rand(0)*2)被再次计算,作为虚表的主键,其值为1(第5次计算),然而1这个主键已经存在于虚拟表中,而新计算的值也为1(主键键值必须唯一),所以插入的时候就直接报错了。

5.整个查询过程floor(rand(0)*2)被计算了5次,查询原数据表3次,所以这就是为什么数据表中需要3条数据,使用该语句才会报错的原因。

这里补充一下5,为什么需要3条数据,看一下floor(rand(0)*2)的执行结果

624704b5db9c3cc2fe6fa539118f9154.png

38acbda7a107f8ec4200a8815e630a00.png

虽然只有2个值,但是你要查到第三条才会有重复啊~~~~~

好了,最后可以总结一下,SELECT distinct concat(0x23,PersonID,0x3a,Password,0x23) FROM person limit 0,1就是查想要的数据,floor(rand(0) * 2)是为了生成一个不唯一的且可重复的数,好让后面能主键重复

concat((SELECT distinct concat(0x23,PersonID,0x3a,Password,0x23) FROM person limit 0,1 ),rand(0) * 2 ),是为了聚合成#1:c4d7b26adbecfc3fedbc895f30099f4b#1的样子,SELECTcount(*), concat( (SELECT distinct concat(0x23,PersonID,0x3a,Password,0x23) FROM person limit 0,1),floor(rand(0) * 2)) xFROMinformation_schema. TABLES GROUP BY  x 是为了把rand count(*),group by凑在一起,因为凑在一起才会计算多次,有主键重复。最外面那层select 1 可以不要。。

看完MYSQL的floor出现报错如何解决这篇文章,大家觉得怎么样?如果想要了解更多相关,可以继续关注我们的行业资讯板块。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值