floor() 函数的作用是返回小于等于该值的最大整数
举例说明:select floor(1.1) from qs_ad_category
上述查询语句的结果为 1 由于 比1.1小的最大整数为 1 所以结果为 1
注意:floor()函数的使用局限:mysql 5.0及以上版本
rand()函数的作用:获取随机的浮点数(小于0的小数),而 rand(0) 则是获取固定的小数值
举例说明:select rand() from qs_ad_category;
结果为随机的浮点型小数:0.7450851357961866
由于rand()函数是获取小于1 的浮点数,也就是例如上述结果中的0.7450851357961866
Floor() function rounds down the value inside the parentheses to the nearest integer that is less than or equal to it, and displays the result.。例如上述rand()的结果为 0.7450851357961866,那么最大整数就是 “0” 所以 :
select floor(rand(0)) from qs_ad_category 的 结果值 为 “0” 。
若是rand()*2,则 rand() 结果可能会大于 1 ,那么结合 floor()函数 ,最终的值可能为 1
select count(*),concat(user(),floor(rand(0)*2))x from information_schema.tables
floor() 报错注入准确地说应该是floor、 count、 group by冲突报错, count(*)、rand()、group by三者缺一不可
count() 函数:计数函数,用来计算数据总和的函数,该函数结果集只有一个。
floor() 函数+rand()函数:获取 0 或 1的整数值
group by 函数:在对数据进行分组时会先看虚拟表中是否存在这个值,不存在就插入;存在的话 count()加1,在使用 group by时 floor(rand(0)2)会被执行一次,若虛表不存在记录,插入虚表时会再执行一次
使用报错获取当前用户信息 select count(*),concat(user(),floor(rand(0)*2))x from information_schema.tables group by x
以上是Mysql中报错函数floor()函数和rand()函数如何配合使用的详细内容。更多信息请关注PHP中文网其他相关文章!