社区所有版块导航
Python
python开源   Django   Python   DjangoApp   pycharm  
DATA
docker   Elasticsearch  
aigc
aigc   chatgpt  
WEB开发
linux   MongoDB   Redis   DATABASE   NGINX   其他Web框架   web工具   zookeeper   tornado   NoSql   Bootstrap   js   peewee   Git   bottle   IE   MQ   Jquery  
机器学习
机器学习算法  
Python88.com
反馈   公告   社区推广  
产品
短视频  
印度
印度  
Py学习  »  DATABASE

MySQL选择10个随机记录,其中至少有一个记录字段具有一定的值

Erik09 • 6 年前 • 1528 次点击  

我试图从一个表中选择3个随机记录,前提是结果至少应包括一个值“数字”大于3的记录。

实例表:

+--------+-------+--------+
| ID     | name  | number |
+--------+-------+--------+
| 1      | name1 | 5      |
+--------+-------+--------+
| 2      | name2 | 0      |
+--------+-------+--------+
| 3      | name3 | 2      |
+--------+-------+--------+
| 4      | name4 | 7      |
+--------+-------+--------+
| 5      | name5 | 9      |
+--------+-------+--------+
| 6      | name6 | 1      |
+--------+-------+--------+
| etc... |       |        |
+--------+-------+--------+

因此,结果可能是ID为1、2和6的记录。或1,4和9。但不是2、3和6,因为该结果不包括至少一个“数字”为3的记录。

我尝试过此操作,但它无法返回始终至少包含一个值为>3的记录的结果:

SELECT name, number  FROM   table
WHERE  EXISTS (
   SELECT number FROM table
   WHERE  number > 3
   ) 
ORDER BY RAND()
LIMIT 3

我想我走错了。任何帮助都将不胜感激!

Python社区是高质量的Python/Django开发社区
本文地址:http://www.python88.com/topic/31140
 
1528 次点击  
文章 [ 1 ]  |  最新文章 6 年前
forpas
Reply   •   1 楼
forpas    6 年前

通过使用交叉联接创建要从中选择的所有可能组合的CTE:

WITH cte AS (
  SELECT 
    n1.id id1, n1.name name1, n1.number number1,
    n2.id id2, n2.name name2, n2.number number2,
    n3.id id3, n3.name name3, n3.number number3
  FROM numbers n1 CROSS JOIN numbers n2 CROSS JOIN numbers n3
  WHERE 
    (n1.number > 3 OR n2.number > 3 OR n3.number > 3)
    AND n1.id <> n2.id AND n1.id <> n3.id AND n3.id <> n2.id
  ORDER BY RAND() LIMIT 1
)

SELECT id1 id, name1 name, number1 number FROM cte
UNION ALL
SELECT id2 id, name2 name, number2 number FROM cte
UNION ALL
SELECT id3 id, name3 name, number3 number FROM cte

demo