Mysql中报错函数floor()函数和rand()函数如何配合使用
1. floor 函数
1.1 floor 函数的作用
floor() 函数的作用是返回小于等于该值的最大整数
举例说明:select floor(1.1) from qs_ad_category
上述查询语句的结果为 1 由于 比1.1小的最大整数为 1 所以结果为 1

注意:floor()函数的使用局限:mysql 5.0及以上版本
2. rand() 函数
2.1 rand() 函数的作用
rand()函数的作用:获取随机的浮点数(小于0的小数),而 rand(0) 则是获取固定的小数值
举例说明:select rand() from qs_ad_category;
结果为随机的浮点型小数:0.7450851357961866

3. floor() 函数 配合 rand() 函数
3.1 两个组合函数的使用
由于rand()函数是获取小于1 的浮点数,也就是例如上述结果中的0.7450851357961866
动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版
动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联J*aScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR*函数库的强大功能,对常用的、强大的包
525
查看详情
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
4. 以 floor() 函数为主的报错注入
4.1 报错注入的组成部分
floor() 报错注入准确地说应该是floor、 count、 group by冲突报错, count(*)、rand()、group by三者缺一不可
4.2 报错注入组成部分解析
count() 函数:计数函数,用来计算数据总和的函数,该函数结果集只有一个。
floor() 函数+ran
d()函数:获取 0 或 1的整数值
group by 函数:在对数据进行分组时会先看虚拟表中是否存在这个值,不存在就插入;存在的话 count()加1,在使用 group by时 floor(rand(0)2)会被执行一次,若虛表不存在记录,插入虚表时会再执行一次
4.3 显错注入
使用报错获取当前用户信息 select count(*),concat(user(),floor(rand(0)*2))x from information_schema.tables group by x
以上就是Mysql中报错函数floor()函数和rand()函数如何配合使用的详细内容,更多请关注其它相关文章!
