मैंने MySQL के ORDER BY RAND ()
फ़ंक्शन पर कुछ विकल्प पढ़ा है, लेकिन अधिकांश विकल्प का केवल एक यादृच्छिक परिणाम की आवश्यकता है, जहां पर लागू होते हैं।
क्या किसी को कोई भी विचार है कि एक क्वेरी को अनुकूलित करने का तरीका क्या है जो कई यादृच्छिक परिणाम देता है, जैसे कि:
का चयन करें यू.आई.डी., पी.फ़ोटो यूजर यू से, प्रोफाइल पी WHERE p.memberid = u.id और p.photo! = '' AND (u.ownership = 1 या u.stamp = 1) आदेश द्वारा रैंड () सीमा 18
यह एक विकल्प है, लेकिन यह अभी भी RAND () का उपयोग करने पर आधारित है:
SELECT u.id , पी। फोटो, राउण्ड (रैंड (* * x.m_id) 'प्रयोक्ता यू, प्रोफाइल पी, (चयन MAX (टी.आईडी)' एम_आईड 'से उपयोगकर्ता टी) एक्स जहां पी। मेम्बरिड = यूआईड और P.photo! = '' AND (u.ownership = 1 या u.stamp = 1) ORDER द्वारा rand_ind LIMIT 18
यह थोड़ा अधिक जटिल है, लेकिन random_ind का बेहतर वितरण प्रदान करता है मान:
SELECT u.id, p.photo, FLOOR (1 + RAND () * x.m_id) 'rand_ind' उपयोगकर्ता से, प्रोफाइल पी, (चयन करें MAX (टी.आईडी) - 1 'एम_आईडी' से उपयोगकर्ता टी) x जहां पी। मेम्बरिड = यू.आईडी और पी.फोटो! = '' और (यू.नरशिप = 1 या यू.स्टैम्प = 1 ) आदेश रैंड_आईडी LIMIT 18
No comments:
Post a Comment