随机获取表若干行
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了随机获取表若干行,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3069字,纯文字阅读大概需要5分钟。
内容图文
过程执行后会随机从表中筛选指定数目的记录返回。过程包含三个参数,分别是表名,行数和主键id。过程只支持int类型单主键的表。主键可以省略为空,这样过程会自动查找主键,不过这样比较慢。 MySQL CREATE DEFINER=`root`@`%` PROCEDURE `rand_data`(IN `tbN
过程执行后会随机从表中筛选指定数目的记录返回。过程包含三个参数,分别是表名,行数和主键id。过程只支持int类型单主键的表。主键可以省略为空,这样过程会自动查找主键,不过这样比较慢。 MySQLCREATE DEFINER=`root`@`%` PROCEDURE `rand_data`(IN `tbName` VARCHAR(50), IN `rowCnt` INT, IN `tbKey` VARCHAR(50)) LANGUAGE SQL NOT DETERMINISTIC CONTAINS SQL SQL SECURITY DEFINER COMMENT '随机获取若干记录,只适用于单主键表' BEGIN #获取主键名 IF tbKey IS NOT NULL THEN SET @tbKey=tbKey;#参数里面已经有,这种情况比较快 ELSE #参数里面没,从系统表查找主键,比较耗时 SELECT @tbKey:=c.COLUMN_NAME FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS AS t, INFORMATION_SCHEMA.KEY_COLUMN_USAGE AS c WHERE t.TABLE_NAME = c.TABLE_NAME AND t.TABLE_SCHEMA = c.TABLE_SCHEMA AND t.TABLE_SCHEMA = database() AND t.TABLE_NAME = tbName AND t.CONSTRAINT_TYPE = 'PRIMARY KEY'; END IF; #获取最大id,最小id和记录数 SET @getMaxIdSql = CONCAT('SELECT @maxId:=MAX(', @tbKey, '),', '@minId:=MIN(', @tbKey, '),', '@totalCnt:=COUNT(', @tbKey, ')', ' FROM `', tbName, '`;'); PREPARE getMaxId FROM @getMaxIdSql; EXECUTE getMaxId; DEALLOCATE PREPARE getMaxId; #创建临时表 DROP TABLE IF EXISTS rand_tt; SET @temTbSql = CONCAT('CREATE TEMPORARY TABLE rand_tt SELECT 0 aid,tb.* FROM `',tbName,'` tb LIMIT 0;'); PREPARE temTb FROM @temTbSql; EXECUTE temTb; DEALLOCATE PREPARE temTb; #构建获取一条记录的sql SET @randRowSql = CONCAT('INSERT INTO rand_tt SELECT @cnt:=@cnt+1 aid,tb.* FROM ', tbName, ' tb WHERE tb.', @tbKey, '=?;'); PREPARE addRow FROM @randRowSql; #生成随机记录 SET @cnt=0; insertLoop: LOOP SET @id=FLOOR(RAND()*(@maxId-@minId)+@minId); IF NOT EXISTS (SELECT id FROM rand_tt WHERE id=@id) THEN EXECUTE addRow USING @id; IF @cnt >= rowCnt OR @cnt >= @totalCnt THEN LEAVE insertLoop; END IF; END IF; END LOOP insertLoop; DEALLOCATE PREPARE addRow; #返回数据 ALTER TABLE rand_tt DROP COLUMN aid; SELECT * FROM rand_tt; END
内容总结
以上是互联网集市为您收集整理的随机获取表若干行全部内容,希望文章能够帮你解决随机获取表若干行所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。