>  기사  >  데이터 베이스  >  mysql随机取数_MySQL

mysql随机取数_MySQL

WBOY
WBOY원래의
2016-06-01 13:06:591130검색

order by RAND() 效率太差.

我的主键为string,网上的高效语句也无法用上.于是自己琢磨了个新的随机取数处理方法. 未做测试.先记录下.

第一步,获取将要获取的数量的总数量.

 string hql_nums = "select COUNT(*) from Table where a='" + a+ "'"; int allnums = MysqlHibernate.GetInstance().getCout(hql_nums);


第二步.

  Random r = new Random();  int begin = r.Next(allnums - nums); //nums为需要取值数量.防止取数不够

第三步. 以begin为起点, 取2*nums 条数据.然后对数据进行排序.获取需要的nums条数据.




성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.