8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

如何考虑权重并随机选择一行?

JsonKody 1月前

84 0

我有一张如下所示的表:id:主键内容:varcharweight:int 我想要做的是从该表中随机选择一行,但要考虑权重。例如,我...

我有一张如下所示的表格:

id: primary key
content: varchar
weight: int

我想要做的是从该表中随机选择一行,但要考虑权重。例如,如果我有 3 行:

id, content, weight
1, "some content", 60
2, "other content", 40
3, "something", 100

第一行有 30% 的概率被选中,第二行有 20% 的概率被选中,第三行有 50% 的概率被选中。

有办法吗?如果我必须执行 2 或 3 个查询,那不是问题。

帖子版权声明 1、本帖标题:如何考虑权重并随机选择一行?
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由JsonKody在本站《mysql》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 我认为最简单的方法实际上是使用加权水库采样:

    SELECT
      id,
      -LOG(RAND()) / weight AS priority
    FROM
      your_table
    ORDER BY priority
    LIMIT 1;
    

    这是一种很棒的方法,可让您从 N 个元素中选择 M 个,其中每个元素被选中的概率与其权重成正比。当您恰好只想要一个元素时,它同样有效。本文介绍了该方法请注意,它们选择 POW(RAND(), 1/weight) 的最大值,这相当于选择 -LOG(RAND()) / weight 的最小值。

返回
作者最近主题: