Maison  >  Article  >  base de données  >  mysql随机取数_MySQL

mysql随机取数_MySQL

WBOY
WBOYoriginal
2016-06-01 13:06:591127parcourir

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条数据.




Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn