mysql 随机查询

本文探讨了SQL查询中使用RAND()函数进行随机查询时的优化策略,包括使用JOIN操作和LIMIT子句来提高查询效率。同时,文章比较了WHERE和JOIN在随机查询场景下的性能差异,提供了SQL性能优化的实际案例。
SELECT * FROM `table`
WHERE id >= (SELECT floor( RAND() * ((SELECT MAX(id) FROM `table`)-(SELECT MIN(id) FROM `table`)) + (SELECT MIN(id) FROM `table`)))
ORDER BY id LIMIT 1;

SELECT *
FROM `table` AS t1 JOIN (SELECT ROUND(RAND() * ((SELECT MAX(id) FROM `table`)-(SELECT MIN(id) FROM `table`))+(SELECT MIN(id) FROM `table`)) AS id) AS t2
WHERE t1.id >= t2.id
ORDER BY t1.id LIMIT 1;

join 优于where
<?php // 页面加载时生成随机4位数字 $user_code = rand(1000, 9999); ?> <?php // 数据库连接信息 $servername = "localhost"; $username = "root"; $password = "root"; $dbname = "honey_teach"; // 创建数据库连接 $conn = new mysqli($servername, $username, $password, $dbname); // 检查连接是否成功 if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); } // 处理表单提交 if ($_SERVER["REQUEST_METHOD"] == "POST") { // 获取表单数据 $Form_username = $_POST['username']; $Form_password = $_POST['userpass']; $Form_confirm_password = $_POST['userpass']; // 这里确认密码和密码字段名一样,实际使用时可能需要修改 $Form_email = $_POST['email']; $Form_phone_number = $_POST['iphone']; $Form_verification_code = $_POST['yzm']; // 防止 SQL 注入 $Form_username = $conn->real_escape_string($Form_username); $Form_password = $conn->real_escape_string($Form_password); $Form_confirm_password = $conn->real_escape_string($Form_confirm_password); $Form_email = $conn->real_escape_string($Form_email); $Form_phone_number = $conn->real_escape_string($Form_phone_number); $Form_verification_code = $conn->real_escape_string($Form_verification_code); // 插入数据到数据库 $sql = "INSERT INTO username (Form_username, Form_password, Form_confirm_password, Form_email, Form_phone_number, Form_verification_code) VALUES ('$Form_username', '$Form_password', '$Form_confirm_password', '$Form_email', '$Form_phone_number', '$Form_verification_code')"; if ($conn->query($sql) === TRUE) { echo "注册成功"; } else { echo "注册失败: " . $conn->error; } } // 关闭数据库连接 $stmt->close(); $conn->close(); ?> <!doctype html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width,initial-scale=1"> <title>"花公子"蜂蜜网站-注册</title> </head> <body> <form method="post" action=""> <label>用户名:</label><input type=text name=username><br> <label>密   码:</label><input type=password name=userpass><br> <label>确认密码:</label><input type=password name=userpass><br> <label>电子邮箱:</label><input type=text name=email><br> <label>电话号码:</label><input type=text name=iphone><br> <label>验证码:</label><input type=text name=yzm><?php echo"$user_code"?><br> <input type="submit" name=tj><input type="reset" name=cz><br> </form> </body>
最新发布
10-30
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值